html{height:100%}
body{min-height:100%;margin:0;color:#f7f1e8;background:#07070b;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;overflow-x:hidden}
*{box-sizing:border-box}
a{color:inherit}

.skip{position:absolute;left:-999px;top:10px;padding:10px 12px;border-radius:12px;background:rgba(255,255,255,0.12);backdrop-filter:blur(10px);z-index:30}
.skip:focus{left:12px}

.stage{position:fixed;inset:0;z-index:-1;overflow:hidden;isolation:isolate}
.stageCanvas{position:absolute;inset:0;width:100%;height:100%;display:block}
.stageVignette{position:absolute;inset:-20%;background:radial-gradient(circle at 50% 35%,rgba(0,0,0,0) 0%,rgba(0,0,0,0.35) 55%,rgba(0,0,0,0.85) 100%);pointer-events:none}
.stageGrain{position:absolute;inset:0;pointer-events:none;opacity:0.12;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E")}

.topbar{position:fixed;left:0;right:0;top:0;display:flex;gap:10px;align-items:center;justify-content:space-between;padding:14px 18px;padding-top:calc(14px + env(safe-area-inset-top));background:rgba(7,7,11,0.45);backdrop-filter:blur(18px);border-bottom:1px solid rgba(231,176,122,0.18);z-index:20}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;min-width:150px}
.brandMark{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;background:radial-gradient(circle at 30% 30%,rgba(231,176,122,0.9),rgba(231,176,122,0.2) 60%,rgba(255,255,255,0) 70%);border:1px solid rgba(231,176,122,0.3);box-shadow:0 12px 42px rgba(0,0,0,0.45);font-family:"Bodoni Moda",serif;font-weight:600;letter-spacing:0.02em}
.brandText{font-family:"Cormorant Garamond",serif;font-size:18px;letter-spacing:0.04em}

.nav{display:flex;gap:8px;align-items:center;justify-content:center;flex:1}
.navBtn{appearance:none;border:1px solid rgba(255,255,255,0.16);background:rgba(255,255,255,0.06);color:rgba(247,241,232,0.92);padding:9px 12px;border-radius:12px;cursor:pointer;font-size:13px;letter-spacing:0.02em;transition:transform 180ms ease,border-color 180ms ease,background 180ms ease}
.navBtn:hover{transform:translateY(-1px);border-color:rgba(231,176,122,0.38);background:rgba(231,176,122,0.06)}

.actions{display:flex;gap:10px;align-items:center;min-width:190px;justify-content:flex-end}

.btn{appearance:none;border:1px solid rgba(255,255,255,0.2);color:#f7f1e8;background:linear-gradient(180deg,rgba(255,255,255,0.12),rgba(255,255,255,0.03));padding:10px 14px;border-radius:14px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:10px;font-weight:600;letter-spacing:0.01em;transition:transform 180ms ease,border-color 180ms ease,background 180ms ease}
.btn:hover{transform:translateY(-1px);border-color:rgba(255,255,255,0.35)}
.btn:active{transform:translateY(0)}
.btnDot{width:9px;height:9px;border-radius:999px;background:#e7b07a;box-shadow:0 0 20px rgba(231,176,122,0.75)}
.btnPrimary{background:linear-gradient(180deg,rgba(231,176,122,0.34),rgba(231,176,122,0.12));border-color:rgba(231,176,122,0.45)}
.btnPrimary:hover{border-color:rgba(231,176,122,0.65)}
.btnGhost{background:rgba(255,255,255,0.04)}

.page{min-height:100svh}
.section{min-height:100svh;display:grid;place-items:center;padding:clamp(18px,6vw,64px)}
.heroInner{max-width:980px;text-align:center}
.heroTitle{font-family:"Bodoni Moda",serif;font-weight:500;font-size:clamp(42px,8vw,98px);letter-spacing:-0.015em;margin:0 0 6px}
.heroSub{margin:0 auto 18px;max-width:64ch;font-family:"Cormorant Garamond",serif;font-size:clamp(18px,2.2vw,24px);opacity:0.92}
.heroCtas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:12px}
.heroMeta{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:18px}
.pill{font-size:12px;padding:8px 10px;border-radius:999px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.14);letter-spacing:0.04em;text-transform:uppercase}

.scrollHint{display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:34px;opacity:0.78;font-size:12px;letter-spacing:0.18em;text-transform:uppercase}
.scrollLine{width:1px;height:48px;background:linear-gradient(180deg,rgba(231,176,122,0),rgba(231,176,122,0.8),rgba(231,176,122,0));animation:scrollPulse 2.1s ease-in-out infinite}
@keyframes scrollPulse{0%{transform:translateY(-8px);opacity:0.4}50%{transform:translateY(8px);opacity:0.95}100%{transform:translateY(-8px);opacity:0.4}}

.chapterCard{width:min(980px,92vw);border-radius:22px;padding:clamp(16px,3.6vw,28px);background:rgba(10,9,13,0.55);border:1px solid rgba(231,176,122,0.18);backdrop-filter:blur(18px);box-shadow:0 22px 70px rgba(0,0,0,0.55)}
.chapterTitle{font-family:"Bodoni Moda",serif;font-weight:500;font-size:clamp(28px,4.2vw,46px);margin:0 0 10px}
.chapterText{margin:0;max-width:70ch;font-family:"Cormorant Garamond",serif;font-size:clamp(18px,2.2vw,22px);opacity:0.9;line-height:1.5}

.chapterGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.stat{border-radius:18px;padding:14px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.12)}
.statNum{font-size:22px;font-weight:700;letter-spacing:0.02em}
.statLabel{font-size:12px;letter-spacing:0.14em;text-transform:uppercase;opacity:0.72;margin-top:6px}

.note{margin-top:16px;border-radius:18px;padding:14px;background:linear-gradient(180deg,rgba(255,255,255,0.06),rgba(255,255,255,0.03));border:1px solid rgba(255,255,255,0.14)}
.noteTitle{font-size:12px;letter-spacing:0.18em;text-transform:uppercase;opacity:0.78}
.noteText{margin-top:6px;font-family:"Cormorant Garamond",serif;font-size:20px;opacity:0.9}

.footer{padding:18px 18px calc(18px + env(safe-area-inset-bottom))}
.footerInner{max-width:1080px;margin:0 auto;display:flex;justify-content:space-between;gap:12px;align-items:center;border-top:1px solid rgba(255,255,255,0.12);padding-top:14px}
.footerLeft{font-size:12px;opacity:0.75;letter-spacing:0.08em;text-transform:uppercase}
.footerLink{font-size:12px;opacity:0.82;text-decoration:none;border-bottom:1px solid rgba(231,176,122,0.35)}
.footerLink:hover{opacity:1}

.overlay{position:fixed;inset:0;background:rgba(7,7,11,0.46);backdrop-filter:blur(16px);display:none;z-index:50;padding:calc(18px + env(safe-area-inset-top)) 18px calc(18px + env(safe-area-inset-bottom));overflow:hidden;isolation:isolate}
.overlay::before{content:"";position:absolute;inset:0;pointer-events:none;background:
  radial-gradient(circle at 30% 22%,rgba(231,176,122,0.15),rgba(0,0,0,0) 58%),
  radial-gradient(circle at 68% 78%,rgba(231,176,122,0.10),rgba(0,0,0,0) 62%),
  radial-gradient(circle at 72% 28%,rgba(132,167,255,0.08),rgba(0,0,0,0) 60%);
  mix-blend-mode:screen;opacity:0.95;animation:overlayDrift 14s ease-in-out infinite}
@keyframes overlayDrift{0%{transform:translate3d(-1.5%,1%,0) scale(1.02)}50%{transform:translate3d(1.5%,-1.2%,0) scale(1.03)}100%{transform:translate3d(-1.5%,1%,0) scale(1.02)}}

.overlay.open{display:block}
.panel{height:100%;border-radius:22px;background:rgba(10,9,13,0.72);border:1px solid rgba(231,176,122,0.2);padding:16px;overflow:auto;position:relative}
.panelTop{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:12px}
.panelTitle{margin:0;font-family:"Bodoni Moda",serif;font-weight:500;font-size:30px}
.panelSub{font-size:12px;opacity:0.76;letter-spacing:0.12em;text-transform:uppercase;margin-top:6px}
.close{appearance:none;border:1px solid rgba(255,255,255,0.18);background:rgba(255,255,255,0.06);color:#f7f1e8;padding:10px 12px;border-radius:14px;cursor:pointer}
.close:hover{border-color:rgba(231,176,122,0.5)}

.masonry{column-count:3;column-gap:12px}
.ph{break-inside:avoid;border-radius:16px;overflow:hidden;display:block;margin:0 0 12px;border:1px solid rgba(255,255,255,0.14);background:rgba(255,255,255,0.04);transform:translateZ(0);transition:transform 220ms ease,border-color 220ms ease}
.ph:hover{transform:translateY(-2px);border-color:rgba(231,176,122,0.5)}
.ph img{width:100%;height:auto;display:block;filter:contrast(1.05) saturate(0.92) sepia(0.18)}

.lightbox{position:fixed;inset:0;display:none;place-items:center;background:rgba(0,0,0,0.92);z-index:60;padding:calc(18px + env(safe-area-inset-top)) 18px calc(18px + env(safe-area-inset-bottom))}
.lightbox.open{display:grid}
.lbFigure{margin:0;max-width:100%;display:grid;place-items:center;gap:10px}
#lbImg{max-width:94vw;max-height:76vh;border-radius:18px;box-shadow:0 26px 80px rgba(0,0,0,0.7)}
.lbCap{font-size:12px;letter-spacing:0.1em;text-transform:uppercase;opacity:0.76;text-align:center}
.lbClose{position:fixed;top:calc(14px + env(safe-area-inset-top));right:14px;width:46px;height:46px;border-radius:16px;border:1px solid rgba(255,255,255,0.16);background:rgba(255,255,255,0.06);color:#f7f1e8;font-size:26px;cursor:pointer}
.lbClose:hover{border-color:rgba(231,176,122,0.5)}
.lbNav{position:fixed;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:16px;border:1px solid rgba(255,255,255,0.16);background:rgba(255,255,255,0.06);color:#f7f1e8;font-size:30px;cursor:pointer;display:grid;place-items:center}
.lbPrev{left:14px}
.lbNext{right:14px}
.lbNav:hover{border-color:rgba(231,176,122,0.5)}

.entry{background:#07070b}
.entryMain{min-height:100svh;display:grid;place-items:center;padding:24px}
.entryCard{width:min(620px,92vw);border-radius:24px;padding:28px;background:rgba(10,9,13,0.62);border:1px solid rgba(231,176,122,0.18);backdrop-filter:blur(18px);text-align:center}
.entryMark{width:62px;height:62px;border-radius:22px;margin:0 auto 12px;display:grid;place-items:center;font-family:"Bodoni Moda",serif;font-size:30px;background:radial-gradient(circle at 30% 30%,rgba(231,176,122,0.9),rgba(231,176,122,0.16) 62%,rgba(0,0,0,0) 70%);border:1px solid rgba(231,176,122,0.35)}
.entryTitle{margin:0;font-family:"Bodoni Moda",serif;font-weight:500;font-size:58px}
.entrySub{margin:10px auto 18px;max-width:50ch;font-family:"Cormorant Garamond",serif;font-size:20px;opacity:0.9}

.cartCount{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;border-radius:999px;background:rgba(231,176,122,0.18);border:1px solid rgba(231,176,122,0.32);font-size:12px;line-height:1;padding:0 7px}

.contactGrid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:14px;align-items:stretch;margin-top:16px}
.form{display:grid;gap:12px;margin-top:10px}
.fieldRow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field{display:grid;gap:7px;text-align:left}
.field span{font-size:12px;letter-spacing:0.14em;text-transform:uppercase;opacity:0.78}
.field input,.field textarea,.field select{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:15px;padding:12px 12px;border-radius:14px;border:1px solid rgba(255,255,255,0.14);background:rgba(255,255,255,0.06);color:#f7f1e8;outline:none}
.field textarea{resize:vertical;min-height:120px}
.field input:focus,.field textarea:focus,.field select:focus{border-color:rgba(231,176,122,0.55);box-shadow:0 0 0 4px rgba(231,176,122,0.12)}
.formActions{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:flex-start}
.formNote{margin-top:8px;font-size:12px;opacity:0.82;letter-spacing:0.04em;text-align:left}

.mapWrap{border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.03)}
.mapWrap iframe{width:100%;height:340px;border:0;display:block;filter:saturate(0.98) contrast(1.04)}

.productGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.product{border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,0.14);background:rgba(255,255,255,0.04);box-shadow:0 22px 70px rgba(0,0,0,0.45);display:flex;flex-direction:column}
.product img{width:100%;height:220px;object-fit:cover;filter:contrast(1.04) saturate(0.92) sepia(0.16)}
.productMeta{padding:12px;text-align:left;display:grid;gap:6px}
.productTitle{font-family:"Cormorant Garamond",serif;font-size:22px;letter-spacing:0.02em}
.productSub{font-size:12px;letter-spacing:0.14em;text-transform:uppercase;opacity:0.72}
.productRow{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:4px}
.productPrice{font-size:14px;letter-spacing:0.08em;text-transform:uppercase;opacity:0.9}

.drawer{position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(16px);display:none;z-index:70;padding:calc(18px + env(safe-area-inset-top)) 18px calc(18px + env(safe-area-inset-bottom))}
.drawer.open{display:block}
.drawerPanel{position:absolute;top:calc(18px + env(safe-area-inset-top));bottom:calc(18px + env(safe-area-inset-bottom));right:18px;width:min(560px,92vw);border-radius:22px;background:rgba(10,9,13,0.78);border:1px solid rgba(231,176,122,0.2);padding:14px;overflow:auto}
.drawerTop{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:12px}
.cartItems{display:grid;gap:12px;margin-top:6px}
.cartEmpty{padding:16px;border-radius:18px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.12);opacity:0.82}
.cartRow{display:grid;grid-template-columns:86px 1fr;gap:12px;align-items:center;border-radius:18px;padding:10px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.12)}
.cartThumb{width:86px;height:86px;border-radius:14px;object-fit:cover;filter:contrast(1.03) saturate(0.92) sepia(0.14)}
.cartMeta{text-align:left}
.cartTitle{font-weight:700;letter-spacing:0.02em}
.cartSub{margin-top:3px;font-size:12px;letter-spacing:0.12em;text-transform:uppercase;opacity:0.72}
.cartControls{margin-top:10px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.qtyBtn{appearance:none;border:1px solid rgba(255,255,255,0.18);background:rgba(255,255,255,0.06);color:#f7f1e8;padding:8px 12px;border-radius:12px;cursor:pointer}
.qtyBtn:hover{border-color:rgba(231,176,122,0.5)}
.qtyVal{min-width:22px;text-align:center;font-weight:700}
.removeBtn{appearance:none;border:1px solid rgba(255,255,255,0.18);background:rgba(255,255,255,0.04);color:#f7f1e8;padding:8px 12px;border-radius:12px;cursor:pointer;opacity:0.9}
.removeBtn:hover{border-color:rgba(231,176,122,0.5)}
.cartFooter{margin-top:14px;padding-top:14px;border-top:1px solid rgba(255,255,255,0.12);display:grid;gap:10px}
.cartTotalRow{display:flex;justify-content:space-between;align-items:center;letter-spacing:0.06em;text-transform:uppercase}

@media (max-width:900px){
  .nav{display:none}
  .actions{min-width:unset}
  .chapterGrid{grid-template-columns:1fr}
  .masonry{column-count:2}
  .contactGrid{grid-template-columns:1fr}
  .productGrid{grid-template-columns:repeat(2,1fr)}
  .mapWrap iframe{height:280px}
}

@media (max-width:700px){
  .fieldRow{grid-template-columns:1fr}
}

@media (max-width:560px){
  .masonry{column-count:1}
  .brandText{display:none}
  .productGrid{grid-template-columns:1fr}
  .drawerPanel{right:0;left:0;width:auto;border-radius:22px}
}

@media (prefers-reduced-motion: reduce){
  .scrollLine{animation:none}
  .stageGrain{opacity:0.08}
}


/* --- Enhancements & layout fixes (portfolio-ready) --- */

/* Fix: cards inside multi-column grids must be fluid, not viewport sized */
.contactGrid .chapterCard{width:100%}

/* Reduce grain slightly to avoid a pixelated feel while keeping the film texture */
.stageGrain{opacity:0.08}

/* Journey track: creates scroll length for the tunnel experience */
.journeyTrack{width:100%;padding:0;margin:0}
.journeySteps{width:100%}
.journeyStep{min-height:100svh}

/* Floating HUD for the currently focused artwork (click/tap to open) */
.hud{position:fixed;left:18px;bottom:18px;z-index:25;pointer-events:none;max-width:min(360px,calc(100vw - 36px))}
.hudCard{pointer-events:auto;appearance:none;border:1px solid rgba(255,255,255,0.16);background:rgba(10,9,13,0.58);backdrop-filter:blur(18px);
  color:#f7f1e8;border-radius:18px;padding:12px 14px;display:grid;gap:6px;text-align:left;cursor:pointer;box-shadow:0 22px 70px rgba(0,0,0,0.55);
  transform:translateZ(0);transition:transform 180ms ease,border-color 180ms ease,background 180ms ease;}
.hudCard:hover{transform:translateY(-1px);border-color:rgba(231,176,122,0.45);background:rgba(10,9,13,0.62)}
.hudLabel{font-size:11px;letter-spacing:0.14em;text-transform:uppercase;opacity:0.72}
.hudTitle{font-family:"Cormorant Garamond",serif;font-size:20px;letter-spacing:0.01em;line-height:1.2;opacity:0.95}
.hudHint{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;opacity:0.62;display:flex;align-items:center;gap:10px}
.hudPip{width:8px;height:8px;border-radius:999px;background:rgba(231,176,122,0.95);box-shadow:0 0 18px rgba(231,176,122,0.65)}
.hudPlanet .hudPip{background:rgba(255,215,170,0.95)}

/* Contact meta */
.contactMeta{display:grid;gap:8px;margin-top:12px;text-align:left}
.contactLink{width:fit-content;text-decoration:none;border-bottom:1px solid rgba(231,176,122,0.35);font-weight:700;letter-spacing:0.02em}
.contactLink:hover{border-bottom-color:rgba(231,176,122,0.7)}
.contactAddr{font-size:12px;letter-spacing:0.14em;text-transform:uppercase;opacity:0.78}

/* Keep HUD clear on very small screens */
@media (max-width:560px){
  .hud{left:12px;bottom:12px}
  .hudTitle{font-size:18px}
}

.hudCard:disabled{opacity:1;cursor:default}
.hudCard:disabled:hover{transform:none;border-color:rgba(255,255,255,0.16);background:rgba(10,9,13,0.58)}

/* Allow WebGL canvas to receive taps/clicks while the Journey track provides scroll height */
.journeyTrack,.journeySteps,.journeyStep{pointer-events:none}

/* Fix: embedded map must never exceed its grid column */
.contactGrid .mapFrame{width:100%}

/* --- Journey page interaction routing --- */
/* On the tunnel page we want WebGL to be clickable (frames + Venus), while UI remains interactive. */
.journeyPage .stage{z-index:0}
.journeyPage .page{position:relative;z-index:1}
/* Let most of the scroll content be “transparent” to pointer events so clicks land on the canvas. */
.journeyPage .page{pointer-events:none}
/* Re-enable pointer events for intentional UI / controls */
.journeyPage .heroInner,
.journeyPage .heroInner *,
.journeyPage .chapterCard,
.journeyPage .chapterCard *,
.journeyPage .topbar,
.journeyPage .topbar *,
.journeyPage .hud,
.journeyPage .hud *,
.journeyPage .overlay,
.journeyPage .overlay *,
.journeyPage .lightbox,
.journeyPage .lightbox *,
.journeyPage .footer,
.journeyPage .footer *,
.journeyPage .skip{pointer-events:auto}

/* Venus card: keep it out of the way so the planet stays easy to drag */
.journeyPage #venus{place-items:end start}
.journeyPage .venusCard{max-width:min(520px,92vw);margin:0;position:relative;overflow:hidden}
.journeyPage .venusCard > :not(.venusVideo){position:relative;z-index:1}
.journeyPage .venusVideo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0.25;pointer-events:none;border-radius:inherit}

/* During an active orbit drag, prevent accidental page selection */
body.isOrbiting{user-select:none}
