:root{--ink:#0E0E0E;--accent:#6FBEF0;--muted:#5b5b62;--line:rgba(14,14,14,.08)}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--ink);background:#fff;line-height:1.6;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.container {
  width: min(1200px, 92%);
  margin-inline: auto;
}
.back{position:fixed;top:24px;left:24px;z-index:50;display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:rgba(14,14,14,.85);backdrop-filter:blur(16px);color:#fff;border-radius:40px;font-size:13px;font-weight:500;border:1px solid rgba(255,255,255,.1);transition:all .3s}
.back:hover{background:var(--accent);color:#0E0E0E;transform:translateX(-4px)}

.hero{position:relative;min-height:60vh;display:flex;align-items:center;color:#fff;overflow:hidden;padding:140px 0 80px;background:#0E0E0E}
.hero-orb{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(111,190,240,.3),transparent 70%);filter:blur(50px);top:-100px;right:-100px;animation:float 12s ease-in-out infinite}
.hero-orb.o2{left:-200px;top:auto;bottom:-200px;background:radial-gradient(circle,rgba(111,190,240,.15),transparent 70%);animation-delay:-6s}
@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(-40px,30px)}}
.eyebrow{display:inline-block;padding:8px 16px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(14px);border-radius:40px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:28px;position:relative}
h1{font-family:'Playfair Display',serif;font-size:clamp(40px,6vw,72px);line-height:1.05;letter-spacing:-.02em;margin-bottom:20px;position:relative;max-width:880px}
h1 .a{color:var(--accent);font-style:italic}
.hero-sub{font-size:18px;color:rgba(255,255,255,.78);max-width:620px;position:relative}

section{padding:100px 0}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:start}
.contact-info h2{font-family:'Playfair Display',serif;font-size:42px;line-height:1.1;margin-bottom:18px;letter-spacing:-.02em}
.contact-info h2 .a{color:var(--accent);font-style:italic}
.contact-info p{color:var(--muted);font-size:16px;margin-bottom:36px}
.cnt-list{display:flex;flex-direction:column;gap:18px}
.cnt{display:flex;gap:18px;padding:22px;background:#fafafa;border:1px solid var(--line);border-radius:18px;transition:all .35s;align-items:center}
.cnt:hover{background:#0E0E0E;color:#fff;transform:translateX(6px)}
.cnt:hover .cnt-icon{background:var(--accent);color:#0E0E0E}
.cnt:hover .lbl{color:var(--accent)}
.cnt:hover .val{color:#fff}
.cnt-icon{width:50px;height:50px;border-radius:14px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;color:var(--accent);flex-shrink:0;transition:all .35s}
.cnt .lbl{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600}
.cnt .val{font-size:16px;font-weight:600;margin-top:2px}

.form-card{background:#0E0E0E;color:#fff;padding:48px;border-radius:24px;position:relative;overflow:hidden}
.form-card::before{content:"";position:absolute;top:-150px;right:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(111,190,240,.3),transparent 70%);filter:blur(40px)}
.form-card h3{font-family:'Playfair Display',serif;font-size:30px;margin-bottom:8px;position:relative}
.form-card>p{color:rgba(255,255,255,.7);margin-bottom:30px;position:relative}
.form{position:relative;display:flex;flex-direction:column;gap:14px}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.f{display:flex;flex-direction:column;gap:6px}
.f label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.f input,.f select,.f textarea{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);color:#fff;padding:14px 16px;border-radius:12px;font-family:inherit;font-size:14.5px;outline:none;transition:all .3s}
.f input:focus,.f select:focus,.f textarea:focus{border-color:var(--accent);background:rgba(111,190,240,.07)}
.f textarea{resize:vertical;min-height:110px}
.submit{margin-top:10px;padding:16px 28px;border-radius:60px;border:none;background:var(--accent);color:#0E0E0E;font-weight:700;font-size:14.5px;letter-spacing:.04em;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:all .35s}
.submit:hover{background:#fff;transform:translateY(-3px);box-shadow:0 14px 40px -10px rgba(255,255,255,.4)}

.map-section{background:#fafafa}
.map-wrap{display:grid;grid-template-columns:1fr 1.5fr;gap:40px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:0 30px 80px -30px rgba(14,14,14,.15)}
.map-text{padding:50px}
.map-text h3{font-family:'Playfair Display',serif;font-size:32px;line-height:1.1;margin-bottom:14px;letter-spacing:-.02em}
.map-text p{color:var(--muted);margin-bottom:24px}
.map-text .hours{padding:18px;background:#fafafa;border-radius:14px;font-size:14px;color:var(--muted)}
.map-text .hours strong{color:var(--ink);display:block;margin-bottom:6px}
.map-vis{aspect-ratio:16/12;background:url('https://images.unsplash.com/photo-1512453979798-5ea266f8880c?auto=format&fit=crop&w=1400&q=80') center/cover;position:relative}
.map-vis::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(14,14,14,.2),rgba(111,190,240,.25))}
.map-pin{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60px;height:60px;border-radius:50%;background:var(--accent);display:grid;place-items:center;color:#0E0E0E;box-shadow:0 0 0 12px rgba(111,190,240,.3),0 0 0 28px rgba(111,190,240,.15);animation:pulse 2s infinite;z-index:2}
@keyframes pulse{0%,100%{box-shadow:0 0 0 12px rgba(111,190,240,.3),0 0 0 28px rgba(111,190,240,.15)}50%{box-shadow:0 0 0 18px rgba(111,190,240,.4),0 0 0 40px rgba(111,190,240,.1)}}

.reveal{opacity:0;transform:translateY(40px);transition:all 1s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.delay-1{transition-delay:.1s}.delay-2{transition-delay:.2s}

@media(max-width:900px){
  .contact-grid,.map-wrap,.fr{grid-template-columns:1fr;gap:24px}
  .form-card,.map-text{padding:30px}
  section{padding:70px 0}
}