:root { --purple:#7220cf; --purple-dark:#4b148f; --purple-soft:#f4ecff; --ink:#20172e; --muted:#706878; --line:#e8e0ed; }
* { box-sizing:border-box; }
body { margin:0; color:var(--ink); font-family:"Manrope",system-ui,sans-serif; background:#faf9fb; }
a { color:inherit; text-decoration:none; }
img { display:block; max-width:100%; }
.contact-shell { width:min(1180px,calc(100% - 32px)); margin-inline:auto; }
.contact-header { display:flex; align-items:center; justify-content:space-between; gap:24px; width:min(1240px,calc(100% - 32px)); min-height:78px; margin:auto; }
.contact-header img { width:210px; height:58px; object-fit:contain; object-position:left; }
.contact-header nav { display:flex; gap:8px; }
.contact-header nav a { display:inline-flex; align-items:center; gap:7px; min-height:42px; padding:0 13px; border:1px solid var(--line); border-radius:11px; background:#fff; color:#554b60; font-size:.8rem; font-weight:800; }
.contact-header nav a:last-child { border-color:var(--purple); background:var(--purple); color:#fff; }
.contact-header svg { width:17px; }
.contact-hero { padding:78px 0; color:#fff; background:radial-gradient(circle at 85% 20%,rgba(218,177,255,.35),transparent 28%),linear-gradient(135deg,#3b0c70,#7220cf 68%,#8e38df); }
.contact-hero-grid { display:grid; grid-template-columns:1fr 320px; gap:64px; align-items:center; }
.contact-eyebrow { color:#9d45e9; font-size:.76rem; font-weight:900; letter-spacing:.1em; text-transform:uppercase; }
.contact-hero .contact-eyebrow { color:#dec1ff; }
.contact-hero h1 { max-width:780px; margin:10px 0 16px; font-size:clamp(2.7rem,5.5vw,5.1rem); line-height:.98; letter-spacing:-.055em; }
.contact-hero p { max-width:690px; color:rgba(255,255,255,.77); line-height:1.7; }
.contact-hero-actions { display:flex; flex-wrap:wrap; gap:10px; margin-top:26px; }
.contact-hero-actions a { display:inline-flex; align-items:center; gap:9px; min-height:50px; padding:0 18px; border-radius:12px; font-weight:850; }
.contact-primary { background:#1cac61; color:#fff; box-shadow:0 14px 28px rgba(8,100,55,.26); }
.contact-secondary { border:1px solid rgba(255,255,255,.35); background:rgba(255,255,255,.12); color:#fff; }
.contact-hero-actions svg { width:19px; }
.contact-availability { display:flex; gap:14px; padding:20px; border:1px solid rgba(255,255,255,.2); border-radius:17px; background:rgba(255,255,255,.11); backdrop-filter:blur(12px); }
.contact-status { flex:0 0 auto; width:12px; height:12px; margin-top:5px; border:3px solid rgba(255,255,255,.35); border-radius:50%; background:#36d680; box-shadow:0 0 0 5px rgba(54,214,128,.13); }
.contact-availability strong { font-size:.95rem; }
.contact-availability p { margin:6px 0 0; font-size:.78rem; line-height:1.6; }
.contact-channels { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; padding-block:56px; }
.contact-channels article { padding:26px; border:1px solid var(--line); border-radius:17px; background:#fff; box-shadow:0 16px 38px rgba(46,22,70,.07); transition:.2s ease; }
.contact-channels article:hover { transform:translateY(-4px); box-shadow:0 22px 44px rgba(46,22,70,.12); }
.contact-channels article > span { display:grid; place-items:center; width:48px; height:48px; margin-bottom:18px; border-radius:13px; background:var(--purple-soft); color:var(--purple); }
.contact-channels svg { width:22px; }
.contact-channels small { color:var(--purple); font-size:.7rem; font-weight:900; text-transform:uppercase; }
.contact-channels h2 { margin:6px 0 8px; font-size:1.25rem; }
.contact-channels p { min-height:52px; color:var(--muted); font-size:.82rem; line-height:1.55; }
.contact-channels article > a { display:inline-flex; align-items:center; gap:7px; color:var(--purple-dark); font-size:.8rem; font-weight:850; }
.contact-channels article > a svg { width:15px; }
.contact-location { display:grid; grid-template-columns:1fr 1fr; min-height:390px; margin-bottom:56px; overflow:hidden; border:1px solid var(--line); border-radius:22px; background:#fff; box-shadow:0 20px 48px rgba(46,22,70,.09); }
.contact-location-copy { padding:54px; }
.contact-location h2 { max-width:470px; margin:10px 0 15px; font-size:clamp(2rem,4vw,3.2rem); line-height:1.03; letter-spacing:-.045em; }
.contact-location p { color:var(--muted); line-height:1.7; }
.contact-location-copy a { display:inline-flex; align-items:center; gap:8px; margin-top:14px; padding:12px 14px; border-radius:10px; background:var(--purple-soft); color:var(--purple-dark); font-size:.8rem; font-weight:850; }
.contact-location-copy svg { width:18px; }
.contact-map-visual { position:relative; display:grid; place-items:center; align-content:center; color:#fff; background:radial-gradient(circle at center,rgba(255,255,255,.2),transparent 32%),linear-gradient(145deg,#8b3bd8,#46107f); }
.contact-map-visual::before,.contact-map-visual::after { position:absolute; inset:0; opacity:.16; content:""; background-image:linear-gradient(rgba(255,255,255,.8) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.8) 1px,transparent 1px); background-size:44px 44px; transform:rotate(-8deg) scale(1.2); }
.contact-map-pin { z-index:1; display:grid; place-items:center; width:74px; height:74px; margin-bottom:14px; border-radius:50% 50% 50% 8px; transform:rotate(-45deg); background:#fff; color:var(--purple); box-shadow:0 18px 38px rgba(31,7,57,.25); }
.contact-map-pin svg { width:30px; transform:rotate(45deg); }
.contact-map-visual > span,.contact-map-visual > small { z-index:1; }
.contact-map-visual > span { font-size:1.25rem; font-weight:900; }
.contact-map-visual > small { color:rgba(255,255,255,.72); }
.contact-final { display:flex; align-items:center; justify-content:space-between; gap:32px; margin-bottom:70px; padding:38px; border-radius:20px; background:linear-gradient(135deg,#f5edff,#fff); }
.contact-final h2 { margin:6px 0; font-size:2rem; }
.contact-final p { margin:0; color:var(--muted); }
.contact-final > a { display:inline-flex; align-items:center; gap:8px; min-height:48px; padding:0 18px; border-radius:11px; background:linear-gradient(135deg,var(--purple),var(--purple-dark)); color:#fff; font-weight:850; white-space:nowrap; box-shadow:0 12px 26px rgba(75,20,143,.23); }
.contact-final svg { width:18px; }
.contact-footer { display:flex; justify-content:space-between; gap:24px; padding:24px max(24px,calc((100vw - 1180px)/2)); color:rgba(255,255,255,.65); background:#241330; font-size:.76rem; }
.contact-footer a { color:#fff; font-weight:800; }
@media(max-width:800px) {
  .contact-header img { width:160px; }
  .contact-header nav a:first-child { display:none; }
  .contact-hero-grid,.contact-location { grid-template-columns:1fr; }
  .contact-channels { grid-template-columns:1fr; }
  .contact-map-visual { min-height:300px; }
  .contact-final,.contact-footer { align-items:flex-start; flex-direction:column; }
}
