
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Manrope:wght@400;500;600;700&display=swap');

:root{
  --bg:#090807;
  --bg-2:#11100f;
  --paper:#171413;
  --panel:rgba(255,255,255,.045);
  --panel-2:rgba(255,255,255,.07);
  --line:rgba(255,255,255,.11);
  --line-strong:rgba(255,255,255,.18);
  --text:#f4eee8;
  --muted:rgba(244,238,232,.68);
  --gold:#d1a167;
  --gold-2:#f1c589;
  --wine:#7a2b50;
  --wine-2:#a44674;
  --glow:0 28px 80px rgba(0,0,0,.42);
  --soft:0 18px 40px rgba(0,0,0,.24);
  --radius-xl:34px;
  --radius-lg:24px;
  --radius-md:16px;
  --container:min(1380px, calc(100vw - 42px));
  --serif:'Cormorant Garamond', serif;
  --sans:'Manrope', system-ui, sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
  --header:84px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--text);
  background:
    radial-gradient(circle at 10% 10%, rgba(209,161,103,.13), transparent 20%),
    radial-gradient(circle at 84% 12%, rgba(122,43,80,.14), transparent 18%),
    linear-gradient(180deg, #080808 0%, #0b0a09 35%, #0e0c0d 100%);
  overflow-x:hidden;
  opacity:0;
  transition:opacity 1s var(--ease);
}
body.loaded{opacity:1}
body::before{
  content:"";
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    repeating-linear-gradient(90deg, transparent 0, transparent 119px, rgba(255,255,255,.018) 120px),
    linear-gradient(rgba(255,255,255,.02), rgba(255,255,255,.01));
  mix-blend-mode:screen;
  opacity:.42;
}
img{display:block;width:100%;height:100%;object-fit:cover}
a{text-decoration:none;color:inherit}
button{font:inherit}

.scene-noise,.scene-vignette,.scene-beam{position:fixed; inset:0; pointer-events:none; z-index:0}
.scene-noise{
  opacity:.06;
  background-image:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.7) 0.5px, transparent .8px),
    radial-gradient(circle at 80% 40%, rgba(255,255,255,.55) 0.5px, transparent .9px),
    radial-gradient(circle at 40% 80%, rgba(255,255,255,.45) 0.6px, transparent 1px);
  background-size:180px 180px,240px 240px,220px 220px;
}
.scene-vignette{background:radial-gradient(circle at center, transparent 44%, rgba(0,0,0,.28) 100%)}
.scene-beam{
  background:
    radial-gradient(circle at 18% 10%, rgba(209,161,103,.14), transparent 18%),
    radial-gradient(circle at 72% 8%, rgba(164,70,116,.1), transparent 14%);
  filter:blur(18px);
}
.orb{
  position:fixed; border-radius:50%; filter:blur(42px); pointer-events:none; z-index:0; opacity:.6;
}
.orb.a{width:280px;height:280px;left:-4%;top:12%;background:radial-gradient(circle, rgba(209,161,103,.22), transparent 70%)}
.orb.b{width:340px;height:340px;right:-8%;top:26%;background:radial-gradient(circle, rgba(164,70,116,.18), transparent 72%)}
.orb.c{width:260px;height:260px;left:16%;bottom:10%;background:radial-gradient(circle, rgba(209,161,103,.12), transparent 70%)}

.site{position:relative;z-index:1}
.container{width:var(--container);margin:0 auto}
.eyebrow,.nav-links a,.button,.meta,.mini{
  text-transform:uppercase; letter-spacing:.24em; font-size:11px; line-height:1.4;
}

.header{
  position:sticky; top:0; z-index:50; height:var(--header);
  backdrop-filter:blur(16px) saturate(130%); -webkit-backdrop-filter:blur(16px) saturate(130%);
  background:rgba(8,8,8,.58); border-bottom:1px solid var(--line);
}
.header-inner{
  width:var(--container); height:100%; margin:0 auto;
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:18px;
}
.brand{display:flex; flex-direction:column; gap:2px}
.brand b{font-family:var(--serif); font-size:1.75rem; letter-spacing:.05em; line-height:1}
.brand span{font-size:10px; color:var(--muted); letter-spacing:.28em; text-transform:uppercase}
.nav-links{display:flex; gap:24px; justify-content:center}
.nav-links a{position:relative; color:rgba(244,238,232,.82)}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-8px; width:100%; height:1px;
  background:linear-gradient(90deg, var(--gold), var(--wine-2));
  transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease);
}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-links a.active{color:#fff}

.button{
  display:inline-flex; align-items:center; justify-content:center; min-height:50px; padding:0 20px;
  border-radius:999px; border:1px solid var(--line-strong); background:rgba(255,255,255,.04);
  box-shadow:var(--soft); transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .35s ease;
}
.button:hover{transform:translateY(-3px); box-shadow:0 22px 50px rgba(0,0,0,.38)}
.button.primary{
  background:linear-gradient(135deg, rgba(209,161,103,.97), rgba(164,70,116,.9));
  color:#180d11; font-weight:700; border-color:rgba(255,255,255,.08);
}
.button.ghost{background:rgba(255,255,255,.03)}
.button-row{display:flex; gap:14px; flex-wrap:wrap}

.mobile-toggle{display:none; width:46px; height:46px; border-radius:50%; border:1px solid var(--line); background:rgba(255,255,255,.04); color:var(--text)}
.mobile-panel{display:none}

.section{padding:78px 0}
.section-head{
  display:flex; justify-content:space-between; gap:28px; align-items:end;
  padding-bottom:22px; border-bottom:1px solid var(--line); margin-bottom:28px;
}
.section-head h2{
  margin:8px 0 0; font-family:var(--serif); font-size:clamp(2.8rem, 5vw, 5rem); line-height:.9; letter-spacing:-.03em;
}
.section-head p{max-width:560px; margin:0; color:var(--muted); line-height:1.9; font-size:15px}

.hero-a{
  min-height:calc(100vh - var(--header)); display:grid; grid-template-columns:.82fr 1.18fr; gap:28px; align-items:center;
}
.hero-copy{padding:40px 0}
.hero-copy h1{
  margin:0; font-family:var(--serif); font-size:clamp(4rem, 8vw, 8.2rem); line-height:.86; letter-spacing:-.045em; max-width:7ch;
}
.hero-copy h1 em{
  font-style:normal; background:linear-gradient(135deg, var(--gold-2), #fff0d2 32%, var(--wine-2));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero-copy p{max-width:540px; color:var(--muted); line-height:1.95; font-size:15px}
.hero-stats{display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:26px}
.stat{
  padding:18px 16px; border-radius:var(--radius-md); border:1px solid var(--line); background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
}
.stat strong{display:block; font-family:var(--serif); font-size:2.35rem; line-height:1}
.stat span{display:block; margin-top:6px; color:var(--muted); font-size:13px}

.collage{
  position:relative; min-height:820px; perspective:2000px; transform-style:preserve-3d;
}
.card-visual,.glass,.micro{
  position:absolute; transform-style:preserve-3d; will-change:transform;
}
.card-visual{
  overflow:hidden; border-radius:34px; border:1px solid rgba(255,255,255,.14); box-shadow:var(--glow); background:#111;
}
.card-visual::before{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:linear-gradient(130deg, rgba(209,161,103,.18), transparent 36%, transparent 70%, rgba(164,70,116,.16));
}
.card-visual::after{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.04), inset 0 -90px 120px rgba(0,0,0,.34);
}
.visual-main{width:min(74%,650px); height:82%; top:4%; right:2%; transform:translateZ(90px) rotateY(-8deg) rotateX(3deg)}
.visual-side{width:39%; height:32%; left:0; bottom:6%; transform:translateZ(140px) rotateY(14deg) rotateX(5deg)}
.glass{
  padding:22px; border-radius:24px; background:linear-gradient(180deg, rgba(255,255,255,.11), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.14); box-shadow:var(--soft);
  backdrop-filter:blur(20px) saturate(140%); -webkit-backdrop-filter:blur(20px) saturate(140%);
}
.glass.note{width:37%; left:2%; top:10%; transform:translateZ(140px) rotateY(12deg)}
.glass.note p{margin:0; font-family:var(--serif); font-size:clamp(1.25rem, 2vw, 1.9rem); line-height:1.08}
.micro{
  width:34%; right:-1%; bottom:12%; padding:20px; border-radius:24px;
  background:rgba(5,5,5,.78); border:1px solid rgba(255,255,255,.12); box-shadow:0 28px 90px rgba(0,0,0,.52);
  transform:translateZ(180px) rotateY(-18deg) rotateX(6deg);
}
.micro-list{display:grid; gap:10px; margin-top:10px}
.micro-row{display:flex; justify-content:space-between; gap:10px; padding-bottom:8px; border-bottom:1px solid rgba(255,255,255,.08); font-size:13px; color:rgba(244,238,232,.84)}
.micro-row:last-child{border-bottom:0; padding-bottom:0}
.reveal-mask{
  position:absolute; inset:0; z-index:3; transform-origin:left center;
  background:linear-gradient(135deg, rgba(209,161,103,.97), rgba(164,70,116,.95)); transition:transform 1.3s var(--ease);
}
.reveal-visible .reveal-mask{transform:scaleX(0)}

.magazine-grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:22px; align-items:start;
}
.editorial-stack{display:grid; gap:18px}
.panel{
  position:relative; overflow:hidden; border-radius:28px; padding:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid var(--line); box-shadow:var(--soft);
}
.panel h3{margin:10px 0 12px; font-family:var(--serif); font-size:clamp(1.8rem, 2.8vw, 3rem); line-height:.95}
.panel p{margin:0; color:var(--muted); line-height:1.9; font-size:14px}

.picture-window{
  position:relative; min-height:720px; perspective:1800px;
}
.window-large,.window-small,.window-ribbon{
  position:absolute; overflow:hidden; border:1px solid rgba(255,255,255,.14); box-shadow:var(--glow); transform-style:preserve-3d;
}
.window-large{inset:0 14% 8% 0; border-radius:30px; transform:rotateY(7deg) translateZ(40px)}
.window-small{width:42%; height:34%; right:0; top:8%; border-radius:24px; transform:rotateY(-12deg) translateZ(90px)}
.window-ribbon{
  width:42%; right:4%; bottom:3%; padding:22px; border-radius:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.11), rgba(255,255,255,.05)); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  transform:rotateY(-12deg) translateZ(130px);
}
.window-ribbon h3{margin:8px 0 10px; font-family:var(--serif); font-size:2rem; line-height:.95}
.window-ribbon p{margin:0; color:var(--muted); line-height:1.8; font-size:14px}

.bento{
  display:grid; grid-template-columns:repeat(12,1fr); gap:18px;
}
.tile{
  position:relative; overflow:hidden; min-height:300px; border-radius:28px; border:1px solid var(--line); box-shadow:var(--soft); background:rgba(255,255,255,.03);
}
.tile::after{
  content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.58)); z-index:1;
}
.tile.big{grid-column:span 7; min-height:560px}
.tile.mid{grid-column:span 5; min-height:560px}
.tile.half{grid-column:span 6; min-height:360px}
.tile-copy{
  position:absolute; inset:auto 0 0 0; z-index:2; padding:24px;
}
.tile-copy h3{margin:0; font-family:var(--serif); font-size:clamp(1.9rem,2.8vw,3.1rem); line-height:.94}
.tile-copy p{margin:8px 0 0; max-width:34ch; color:rgba(244,238,232,.82); line-height:1.85; font-size:14px}

.runway{
  columns:3 260px; column-gap:18px;
}
.frame{
  break-inside:avoid; margin-bottom:18px; min-height:290px; overflow:hidden; position:relative;
  border-radius:24px; border:1px solid var(--line); box-shadow:var(--soft); background:rgba(255,255,255,.03);
}
.frame.tall{min-height:560px}
.frame.medium{min-height:420px}
.frame.short{min-height:320px}
.frame::after{
  content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.34)); z-index:1; pointer-events:none;
}
.frame-meta{
  position:absolute; left:0; right:0; bottom:0; z-index:2; padding:16px 18px; display:flex; justify-content:space-between; background:linear-gradient(180deg, transparent, rgba(0,0,0,.42));
}

.metrics{
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px;
}
.metric{
  padding:24px; border-radius:24px; border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
}
.metric strong{display:block; font-family:var(--serif); font-size:clamp(2rem,3vw,3rem); margin-bottom:8px}
.metric span{color:var(--muted); line-height:1.8; font-size:14px}

.visit-grid{display:grid; grid-template-columns:.95fr 1.05fr; gap:22px}
.visit-card,.visit-map{
  position:relative; overflow:hidden; border-radius:30px; border:1px solid var(--line); box-shadow:var(--glow);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
}
.visit-card{padding:32px; display:grid; gap:20px}
.visit-card h3{margin:0; font-family:var(--serif); font-size:clamp(2rem,3vw,3.1rem); line-height:.94}
.visit-card p{margin:0; color:var(--muted); line-height:1.9; font-size:14px}
.info-grid{display:grid; gap:16px}
.info-line{display:grid; grid-template-columns:92px 1fr; gap:14px; padding-top:16px; border-top:1px solid var(--line)}
.info-line b{color:var(--muted); font-weight:500}
.visit-map{min-height:600px; display:grid; align-items:end}
.visit-map .overlay{
  position:absolute; inset:0; z-index:1; background:
  radial-gradient(circle at 24% 20%, rgba(209,161,103,.16), transparent 24%),
  linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.44));
}
.floating-card{
  position:relative; z-index:2; margin:22px; max-width:330px; border-radius:24px; padding:22px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
}
.floating-card h4{margin:8px 0 10px; font-family:var(--serif); font-size:2rem; line-height:.94}
.floating-card p{margin:0; color:rgba(244,238,232,.82); line-height:1.8; font-size:14px}

.footer{padding:24px 0 42px}
.footer-inner{
  width:var(--container); margin:0 auto; padding-top:24px; border-top:1px solid var(--line);
  display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; color:var(--muted); font-size:13px;
}

.reveal-up,.reveal-fade,.reveal-tilt{opacity:0; transform:translateY(34px); transition:opacity .9s var(--ease), transform .9s var(--ease)}
.reveal-fade{transform:translateY(16px)}
.reveal-tilt{transform:translateY(38px) rotateX(6deg); transform-origin:center bottom}
.is-visible{opacity:1; transform:none}
.magnetic{will-change:transform}

.layout-overlap{
  display:grid; grid-template-columns:repeat(12,1fr); gap:18px;
}
.block{
  position:relative; overflow:hidden; border-radius:28px; border:1px solid var(--line); background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03)); box-shadow:var(--soft);
}
.block.photo{min-height:520px}
.block.copy{padding:30px}
.block.copy h3{margin:8px 0 12px; font-family:var(--serif); font-size:clamp(2rem,3vw,3rem); line-height:.95}
.block.copy p{margin:0; color:var(--muted); line-height:1.9; font-size:14px}
.span-7{grid-column:span 7}
.span-5{grid-column:span 5}
.span-6{grid-column:span 6}

@media (max-width:1100px){
  .header-inner{grid-template-columns:1fr auto auto}
  .nav-links,.desktop-cta{display:none}
  .mobile-toggle{display:inline-flex; align-items:center; justify-content:center}
  .mobile-panel{
    display:grid; gap:14px; width:var(--container); margin:0 auto; max-height:0; overflow:hidden; transition:max-height .45s var(--ease), padding .45s var(--ease);
  }
  .mobile-panel.open{max-height:320px; padding:10px 0 18px}
  .mobile-panel a{padding:12px 0; border-top:1px solid var(--line)}
  .hero-a,.magazine-grid,.visit-grid{grid-template-columns:1fr}
  .section-head{flex-direction:column; align-items:start}
  .hero-copy{padding:34px 0 0}
  .collage,.picture-window{min-height:860px}
  .metrics{grid-template-columns:repeat(2,1fr)}
  .tile.big,.tile.mid,.tile.half,.span-7,.span-5,.span-6{grid-column:span 12}
}
@media (max-width:760px){
  :root{--container:min(100vw - 24px, 1000px); --header:74px}
  .header{height:74px}
  .brand b{font-size:1.4rem}
  .hero-copy h1{font-size:clamp(3.2rem,16vw,5.8rem); max-width:8ch}
  .hero-stats,.metrics{grid-template-columns:1fr}
  .collage,.picture-window{min-height:680px}
  .visual-main{width:88%; right:0; top:8%; height:70%; transform:translateZ(40px) rotateY(-4deg)}
  .glass.note{width:56%; top:0; left:0}
  .visual-side{width:42%; height:30%; left:2%; bottom:6%}
  .micro{width:54%; right:0; bottom:0}
  .window-ribbon{width:58%}
  .runway{columns:1}
  .info-line{grid-template-columns:1fr}
  .footer-inner{flex-direction:column}
}
