.cnt-hero{background: #181710;padding: 72px 60px 64px;position: relative;overflow: hidden;color: var(--bg);}
[data-theme="dark"] .cnt-hero {color: var(--text);}
.cnt-hero::before{content:'CONTACT';position:absolute;right:-20px;top:50%;transform:translateY(-50%);font-family:var(--font-heading);font-size:clamp(80px,12vw,180px);font-weight:700;color:rgba(255,255,255,0.03);line-height:1;pointer-events:none;letter-spacing:-4px;}
.cnt-hero::after{content:'';position:absolute;bottom:0;left:60px;right:60px;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0.4;}
.cnt-label{font-family:var(--font-body);font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.cnt-title{font-family:var(--font-heading);font-size:clamp(40px,5vw,68px);font-weight:600;line-height:1;letter-spacing:-1px}
.cnt-title em{font-style:italic;color:var(--accent)}
.cnt-sub{margin-top:16px;font-family:var(--font-body);font-size:15px;opacity:0.5;max-width:480px;line-height:1.7}
.cnt-wrap{max-width:1280px;margin:0 auto;padding:80px 60px 100px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
@media(max-width:1024px){.cnt-wrap{grid-template-columns:1fr;gap:60px;padding:60px 40px}}
@media(max-width:640px){.cnt-wrap{padding:48px 24px 60px}}

/* Form Side */
.cnt-form-side .cnt-eyebrow{font-family:var(--font-body);font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.cnt-form-side .cnt-heading{font-family:var(--font-heading);font-size:clamp(28px,4vw,42px);font-weight:600;color:var(--text);line-height:1.05;margin-bottom:32px}
.cnt-form-side .cnt-heading em{font-style:italic;color:var(--accent)}

.cnt-f-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:0}
.cnt-f-grp{margin-bottom:20px;position:relative}
.cnt-f-grp.full{grid-column:1/-1}
.cnt-f-lbl{display:block;margin-bottom:8px;font-family:var(--font-body);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);font-weight:500}
.cnt-req{color:var(--accent)}
.cnt-f-in{width:100%;padding:13px 16px;border:1px solid var(--border);border-bottom:2px solid var(--border);background:var(--card);font-family:var(--font-body);font-size:14px;color:var(--text);transition:all .25s;outline:none}
.cnt-f-in::placeholder{color:var(--muted);opacity:0.6}
.cnt-f-in:focus{border-color:var(--accent);border-bottom-color:var(--accent);background:var(--bg);box-shadow:0 4px 20px rgba(178,141,87,0.1)}
textarea.cnt-f-in{resize:vertical;min-height:130px}

.cnt-send-btn{display:inline-flex;align-items:center;gap:12px;background:var(--text);color:var(--bg);padding:16px 36px;border:none;font-family:var(--font-body);font-size:11px;letter-spacing:2.5px;text-transform:uppercase;font-weight:600;cursor:pointer;transition:all .3s;margin-top:8px;position:relative;overflow:hidden}
.cnt-send-btn::before{content:'';position:absolute;inset:0;background:var(--accent);transform:translateX(-101%);transition:transform .35s ease}
.cnt-send-btn:hover::before{transform:translateX(0)}
.cnt-send-btn span,.cnt-send-btn i{position:relative;z-index:1}

/* Info Side */
.cnt-info-cards{display:flex;flex-direction:column;gap:0;margin-bottom:40px}
.cnt-info-card{display:flex;align-items:flex-start;gap:20px;padding:24px 0;border-bottom:1px solid var(--border)}
.cnt-info-card:first-child{border-top:1px solid var(--border)}
.cnt-i-icon{width:44px;height:44px;flex-shrink:0;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:16px;transition:all .3s}
.cnt-info-card:hover .cnt-i-icon{background:var(--text);border-color:var(--text);color:var(--bg)}
.cnt-i-lbl{font-family:var(--font-body);font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.cnt-i-val{font-family:var(--font-heading);font-size:18px;color:var(--text);font-weight:600;line-height:1.3}
.cnt-i-sub{font-family:var(--font-body);font-size:12px;color:var(--muted);margin-top:3px}

/* Map */
.cnt-map-head{font-family:var(--font-heading);font-size:28px;font-weight:600;color:var(--text);margin-bottom:16px}
.cnt-map-head em{font-style:italic;color:var(--accent)}
.cnt-map-wrap iframe{border-radius:12px;border:1px solid var(--border)}

/* Toast */
.toastWrap{position:fixed;bottom:28px;left:50%;transform:translateX(-50%);z-index:99999;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}
.toast{display:inline-flex;align-items:center;gap:9px;padding:12px 20px;font-family:var(--font-body);font-size:13px;font-weight:500;box-shadow:var(--sh-lg);border-radius:8px;opacity:0;transform:translateY(12px);transition:all .3s ease;white-space:nowrap;border:1px solid;pointer-events:auto}
.toast.show{opacity:1;transform:translateY(0)}
.toast.out{opacity:0;transform:translateY(12px)}
.toast--success{background:var(--success);border-color:var(--success);color:#fff}
.toast--error{background:var(--danger);border-color:var(--danger);color:#fff}

/* ══════════════════════════
   OTP MODAL
══════════════════════════ */
.otpOverlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;visibility:hidden;transition:opacity 0.3s ease, visibility 0.3s ease;padding:20px}
.otpOverlay.active{opacity:1;visibility:visible}
.otpModal{background:var(--card);border-radius:20px;padding:48px 40px 40px;max-width:440px;width:100%;position:relative;text-align:center;box-shadow:var(--sh-xl);transform:translateY(24px) scale(0.97);transition:transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.3s ease;opacity:0}
.otpOverlay.active .otpModal{transform:translateY(0) scale(1);opacity:1}

.otpClose{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:50%;border:1px solid var(--border);background:var(--bg-alt);color:var(--muted);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.otpClose:hover{background:var(--text);color:var(--bg);border-color:var(--text)}

.otpIconWrap{margin-bottom:20px}
.otpIconRing{width:68px;height:68px;border-radius:50%;background:var(--bg-alt);border:2px solid var(--accent);display:inline-flex;align-items:center;justify-content:center;color:var(--accent);font-size:26px;box-shadow:0 4px 20px rgba(178,146,74,0.18);position:relative}
.otpIconRing::after{content:'';position:absolute;inset:-6px;border-radius:50%;border:1px solid rgba(178,146,74,0.25)}

.otpTitle{font-family:var(--font-heading);font-size:1.75rem;font-weight:700;color:var(--text);margin:0 0 10px;line-height:1.2}
.otpDesc{font-family:var(--font-body);font-size:0.875rem;color:var(--muted);margin:0 0 28px;line-height:1.6}
.otpDesc strong{display:block;margin-top:4px;color:var(--text);font-weight:600;font-size:0.9rem;word-break:break-all}

.otpInputRow{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:10px}
.otpBox{width:48px;height:56px;border:2px solid var(--border);border-radius:10px;text-align:center;font-family:var(--font-body);font-size:1.4rem;font-weight:700;color:var(--text);background:var(--bg-alt);outline:none;transition:all 0.2s;caret-color:var(--accent)}
.otpBox:focus{border-color:var(--accent);background:var(--bg);box-shadow:0 0 0 3px rgba(178,146,74,0.15);transform:translateY(-2px)}
.otpBox.filled{border-color:var(--accent);background:var(--bg)}
.otpBox.error{border-color:var(--danger)!important;background:rgba(192,57,43,0.1);box-shadow:0 0 0 3px rgba(192,57,43,0.1)!important;animation:otpShake 0.4s ease}
.otpDash{font-size:1.1rem;color:var(--border);margin:0 2px;user-select:none;line-height:1}
@keyframes otpShake{0%, 100% { transform: translateX(0); } 20% { transform: translateX(-5px); } 40% { transform: translateX(5px); } 60% { transform: translateX(-4px); } 80% { transform: translateX(4px); }}

.otpError{font-family:var(--font-body);font-size:0.8rem;color:var(--danger);min-height:20px;margin-bottom:4px;text-align:center;font-weight:500}

.otpVerifyBtn{width:100%;padding:14px 24px;background:var(--text);color:var(--bg);border:none;border-radius:10px;font-family:var(--font-body);font-size:0.95rem;font-weight:600;letter-spacing:0.04em;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;margin:12px 0 18px;transition:background 0.25s, transform 0.15s, box-shadow 0.25s;overflow:hidden}
.otpVerifyBtn:hover:not(:disabled){background:var(--accent);box-shadow:0 6px 20px rgba(178,146,74,0.35);transform:translateY(-1px)}
.otpVerifyBtn:disabled{opacity:0.6;cursor:not-allowed}
.otpVerifyBtn .spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,0.35);border-top-color:var(--bg);border-radius:50%;animation:otpSpin 0.7s linear infinite;display:none}
.otpVerifyBtn.loading .spinner{display:block}
.otpVerifyBtn.loading #otpVerifyLabel,.otpVerifyBtn.loading #otpVerifyIcon{display:none}
@keyframes otpSpin{to { transform: rotate(360deg); }}

.otpResendRow{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap}
.otpResendText{font-family:var(--font-body);font-size:0.83rem;color:var(--muted)}
.otpResendBtn{font-family:var(--font-body);font-size:0.83rem;font-weight:600;color:var(--accent);background:none;border:none;cursor:pointer;padding:0;transition:all 0.2s;text-decoration:underline;text-decoration-color:transparent}
.otpResendBtn:hover:not(:disabled){text-decoration-color:var(--accent)}
.otpResendBtn:disabled{color:var(--muted);cursor:default;font-weight:400}

.otpSuccessState{display:none;flex-direction:column;align-items:center;gap:12px;padding:10px 0 4px;animation:otpFadeIn 0.5s ease}
.otpSuccessState.show{display:flex}
.otpSuccessIcon{font-size:3rem;color:var(--success);animation:otpBounce 0.5s cubic-bezier(0.34, 1.56, 0.64, 1)}
.otpSuccessMsg{font-family:var(--font-body);font-size:0.95rem;color:var(--text);font-weight:600;line-height:1.6;text-align:center}
.otpSuccessMsg span{display:block;font-weight:400;color:var(--muted);font-size:0.85rem;margin-top:2px}
@keyframes otpFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes otpBounce{0%{transform:scale(0.4);opacity:0}70%{transform:scale(1.15)}100%{transform:scale(1);opacity:1}}

/* Responsive Modal */
@media (max-width: 480px){
  .otpModal{padding:40px 24px 32px}
  .otpBox{width:42px;height:50px;font-size:1.2rem;border-radius:8px}
  .otpInputRow{gap:6px}
  .otpTitle{font-size:1.45rem}
}