/* «Для своих.» — общие стили для всех страниц */
:root{
  --bg:#0d0d0f; --bg-2:#141417; --panel:#17171b;
  --ink:#f4f1ee; --ink-dim:#b9b6b8; --muted:#85828a;
  --brand:#ee355d; --brand-rgb:238,53,93; --cta:#cf2748; --brand-deep:#9e1b3b; --brand-soft:#ff7b94;
  --accent:var(--brand-soft);
  --teal:#56c2c6; --donate:#56c2c6;
  --line:rgba(255,255,255,.10); --line-strong:rgba(255,255,255,.18);
  --surface-1:rgba(255,255,255,.02); --surface-hover:rgba(255,255,255,.05);
  --nav-bg:rgba(13,13,15,.62); --grain-op:.06;
  --tee-fill:#161616; --tee-stroke:rgba(255,255,255,.14);
  --font-display:'Unbounded',sans-serif; --font-body:'Golos Text',system-ui,sans-serif;
  --maxw:1200px; --ease:cubic-bezier(.2,.7,.2,1);
}
html[data-theme="light"]{
  --bg:#f4f0ea; --bg-2:#ffffff; --panel:#f0ece5;
  --ink:#16151a; --ink-dim:#4c4852; --muted:#645f6a;
  --accent:var(--brand-deep); --donate:#0f6e72;
  --line:rgba(0,0,0,.10); --line-strong:rgba(0,0,0,.16);
  --surface-1:rgba(0,0,0,.02); --surface-hover:rgba(0,0,0,.05);
  --nav-bg:rgba(255,255,255,.74); --grain-op:.035; --tee-stroke:rgba(0,0,0,.14);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth; font-size:90%; background:var(--bg); overscroll-behavior-y:none;}
body{margin:0; background:var(--bg); color:var(--ink); font-family:var(--font-body); font-size:15.3px; line-height:1.6; -webkit-font-smoothing:antialiased; overflow-x:hidden; transition:background .3s var(--ease), color .3s var(--ease); min-height:100dvh;}

.atmosphere{position:fixed; inset:0; z-index:-2; pointer-events:none;}
.atmosphere::before{content:""; position:absolute; inset:0;
  background:radial-gradient(60vw 60vw at 82% -8%, rgba(var(--brand-rgb),.22), transparent 60%),
    radial-gradient(50vw 50vw at -10% 30%, rgba(var(--brand-rgb),.10), transparent 55%),
    radial-gradient(70vw 60vw at 50% 120%, rgba(86,194,198,.06), transparent 60%);}
.grain{position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:var(--grain-op); 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='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px;}
section{position:relative;}
.eyebrow{font-family:var(--font-display); font-weight:300; font-size:.74rem; letter-spacing:.34em; text-transform:uppercase; color:var(--accent); display:inline-flex; align-items:center; gap:.7em;}
.eyebrow::before{content:""; width:34px; height:1px; background:var(--brand);}
.section-title{font-family:var(--font-display); font-weight:800; line-height:.92; letter-spacing:-.02em; font-size:clamp(2.2rem,6vw,4.4rem); margin:.4em 0 0;}
.lede{color:var(--ink-dim); max-width:54ch; font-size:1.05rem;}
.logo-mask{display:inline-block; -webkit-mask:url(../logo.svg) no-repeat center/contain; mask:url(../logo.svg) no-repeat center/contain; background-color:var(--brand);}
a.plain{color:inherit; text-decoration:none;}

/* section header with "смотреть все" */
.sec-head{display:flex; justify-content:space-between; align-items:flex-end; gap:20px; flex-wrap:wrap;}
.see-all{font-family:var(--font-display); font-weight:600; font-size:.95rem; color:var(--accent); text-decoration:none; white-space:nowrap; display:inline-flex; align-items:center; gap:.4em; transition:gap .2s;}
.see-all:hover{gap:.7em;}

/* nav */
header.nav{position:sticky; top:0; z-index:60; backdrop-filter:blur(14px); background:var(--nav-bg); border-bottom:1px solid var(--line);}
.nav-inner{display:flex; align-items:center; justify-content:space-between; height:68px; gap:16px;}
.brand{display:flex; align-items:center; gap:11px; text-decoration:none; color:var(--ink);}
.brand .mark{width:37px; height:30px;}
.brand b{font-family:var(--font-display); font-weight:800; font-size:1.05rem; letter-spacing:-.01em;}
.nav-links{display:flex; align-items:center; gap:26px;}
.nav-links a:not(.btn){color:var(--ink-dim); text-decoration:none; font-size:.95rem; font-weight:500; transition:color .2s;}
.nav-links a:not(.btn):hover{color:var(--ink);}
.nav-links a.active{color:var(--ink);}
.nav-tools{display:flex; align-items:center; gap:10px; position:relative;}
.icon-btn{background:none; border:1px solid var(--line-strong); color:var(--ink); width:44px; height:44px; border-radius:12px; cursor:pointer; display:grid; place-items:center; transition:border-color .2s, background .2s; position:relative;}
.icon-btn:hover{border-color:var(--ink); background:var(--surface-hover);}
.icon-btn svg{width:20px; height:20px;}
.cart-badge{position:absolute; top:-7px; right:-7px; min-width:19px; height:19px; padding:0 5px; border-radius:10px; background:var(--brand); color:#fff; font-size:.66rem; font-weight:800; display:none; place-items:center; font-family:var(--font-display);}
.cart-badge.show{display:grid;}
.burger{display:none;}

.theme-pop{position:absolute; top:54px; right:0; width:248px; background:var(--bg-2); border:1px solid var(--line-strong); border-radius:16px; padding:16px; z-index:70; box-shadow:0 24px 60px rgba(0,0,0,.4);}
.tp-row{margin-bottom:14px;} .tp-row:last-child{margin-bottom:0;}
.tp-lbl{display:block; font-family:var(--font-display); font-weight:600; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:9px;}
.tp-seg{display:flex; gap:6px;}
.tp-seg button{flex:1; padding:9px 6px; border:1px solid var(--line-strong); background:transparent; color:var(--ink-dim); border-radius:10px; cursor:pointer; font-family:var(--font-body); font-size:.85rem; transition:all .15s;}
.tp-seg button:hover{color:var(--ink);}
.tp-seg button[aria-pressed="true"]{background:var(--ink); color:var(--bg); border-color:var(--ink);}
.tp-acc{display:flex; gap:10px;}
.tp-acc button{width:34px; height:34px; border-radius:50%; border:2px solid transparent; cursor:pointer; background:var(--sw); outline-offset:2px; transition:transform .15s;}
.tp-acc button:hover{transform:scale(1.12);}
.tp-acc button[aria-pressed="true"]{border-color:var(--ink); transform:scale(1.12);}

.btn{display:inline-flex; align-items:center; justify-content:center; gap:.55em; font-family:var(--font-display); font-weight:600; font-size:.98rem; padding:15px 26px; border-radius:999px; text-decoration:none; cursor:pointer; border:1px solid transparent; transition:transform .18s var(--ease), background .2s, color .2s, border-color .2s; min-height:52px;}
.btn-primary{background:var(--cta); color:#fff;}
.btn-primary:hover{transform:translateY(-2px); background:var(--brand-soft); color:#1a0a0f;}
.btn-ghost{background:transparent; color:var(--ink); border-color:var(--line-strong);}
.btn-ghost:hover{transform:translateY(-2px); border-color:var(--ink); background:var(--surface-hover);}
.btn-block{width:100%;}

/* hero */
.hero{padding-top:clamp(24px,4dvh,90px); padding-bottom:clamp(24px,4dvh,110px);}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:start;}
.hero h1{font-family:var(--font-display); font-weight:900; letter-spacing:-.04em; line-height:.88; font-size:clamp(3rem,8vw,7.2rem); margin:0 0 .14em;}
.hero h1 .dot{color:var(--brand);}
.hero h1 .thin{display:block; font-weight:300; font-size:.5em; letter-spacing:-.01em; color:var(--ink-dim); line-height:1.2; margin-bottom:.22em;}
.hero p.sub{font-size:1.18rem; color:var(--ink-dim); max-width:48ch; margin:0 0 30px;}
.hero-actions{display:flex; flex-wrap:wrap; gap:14px;}
.spec-row{display:flex; flex-wrap:wrap; gap:10px; margin-top:34px;}
.chip{font-size:.82rem; color:var(--ink-dim); border:1px solid var(--line); padding:8px 14px; border-radius:999px; background:var(--surface-1);}
.chip b{color:var(--ink); font-weight:600;}
.chip.hot{border-color:rgba(var(--brand-rgb),.5); color:var(--accent);}
.hero-visual{position:relative; aspect-ratio:4/5; margin-left:auto; width:min(480px,40dvh,100%);}
.blob-photo{position:absolute; inset:6%; overflow:hidden; border-radius:47% 53% 48% 52% / 54% 46% 54% 46%; cursor:pointer;}
.blob-photo img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0; transition:opacity 1.1s var(--ease);}
.blob-photo img.on{opacity:1;}
.blob-bg{position:absolute; inset:-6% -6% -6% -6%; z-index:-1;}
.sticker{position:absolute; right:-6%; top:-7%; width:128px; height:128px; background:var(--bg-2); border:1px solid var(--line-strong); border-radius:50%; display:grid; place-items:center; box-shadow:0 18px 50px rgba(0,0,0,.5);}
.sticker .logo-mask{width:80px; height:66px;}
.price-tag{position:absolute; left:-5%; bottom:6%; background:#fff; color:#101012; border-radius:16px; padding:12px 16px; font-family:var(--font-display); box-shadow:0 18px 50px rgba(0,0,0,.5); transform:rotate(-4deg);}
.price-tag small{display:block; font-size:.6rem; letter-spacing:.16em; text-transform:uppercase; color:#8a3a48; font-weight:600;}
.price-tag b{font-size:1.35rem; font-weight:800;}
.splatter{position:absolute; inset:0; z-index:-1; pointer-events:none;}
.splatter i{position:absolute; background:var(--brand); border-radius:50%; opacity:.85;}

/* hero carousel: all slides stacked in one CSS-grid cell so the tallest sets the
   height for everyone (no jump on crossfade) — slide 0 stays hand-authored static
   markup with its page-load reveal; slides 1+ are injected by JS from hero_slides.
   Each slide is a flex column so an optional element (e.g. the marquee band) can
   sit below the main grid while the grid itself flexes to fill the rest. */
.hero-slides-stage{display:grid; grid-template-columns:minmax(0,1fr);}
.hero-slides-stage > .hero-slide{grid-area:1/1; min-width:0; height:100%; display:flex; flex-direction:column; opacity:0; visibility:hidden; pointer-events:none; transition:opacity .7s var(--ease), visibility .7s var(--ease);}
.hero-slides-stage > .hero-slide.is-active{opacity:1; visibility:visible; pointer-events:auto;}
.hero-slide > .hero-grid{flex:1 1 auto; min-height:0;}
.hero-slide-title{font-family:var(--font-display); font-weight:800; letter-spacing:-.02em; line-height:.95; font-size:clamp(2.4rem,6vw,4.2rem); margin:.2em 0 .18em;}
.hero-dots{display:none; gap:9px; justify-content:center; margin-top:30px;}
.hero-dots.show{display:flex;}
.hero-dots button{width:9px; height:9px; border-radius:50%; border:none; background:var(--line-strong); cursor:pointer; padding:0; transition:background .2s, transform .2s;}
.hero-dots button[aria-current="true"]{background:var(--brand); transform:scale(1.35);}

/* slide type "text": bold weight-contrast headline (echoes the h1 "thin+900" trick),
   layered photo stack with a spinning percent badge, and a graffiti-ticker band —
   same signature devices as slide 1, recombined so this slide reads as its sibling. */
.philosophy-title{font-size:clamp(2.6rem,6.4vw,4.6rem);}
.philosophy-title .thin{display:block; font-weight:300; font-size:.42em; letter-spacing:-.01em; color:var(--ink-dim); line-height:1.15; margin-bottom:.15em;}
.philosophy-title .dot{color:var(--brand);}
.photo-stack{position:relative; aspect-ratio:4/5; margin-left:auto; width:min(480px,40dvh,100%); overflow:hidden; border-radius:26px;}
.photo-stack img{position:absolute; border-radius:20px; object-fit:cover; box-shadow:0 20px 40px rgba(0,0,0,.4); transition:transform .5s var(--ease);}
.photo-stack img:nth-of-type(1){width:52%; height:58%; left:5%; top:7%; transform:rotate(-8deg); z-index:1; filter:saturate(.9);}
.photo-stack img:nth-of-type(2){width:58%; height:66%; left:21%; bottom:5%; transform:rotate(-2deg); z-index:2; box-shadow:0 26px 50px rgba(0,0,0,.46);}
.photo-stack:hover img:nth-of-type(1){transform:rotate(-11deg) translate(-3%,2%);}
.photo-stack:hover img:nth-of-type(2){transform:rotate(2deg) translate(3%,-2%);}
.photo-stack .stack-blob{position:absolute; inset:2%; z-index:0; opacity:.85;}
.percent-badge{position:absolute; left:-6%; bottom:-4%; width:118px; height:118px; border-radius:50%; background:var(--brand); color:#fff; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; box-shadow:0 18px 46px rgba(0,0,0,.5); z-index:4;}
.percent-badge::before{content:""; position:absolute; inset:-7px; border-radius:50%; border:1.5px dashed rgba(255,255,255,.55); animation:spin 16s linear infinite;}
.percent-badge b{font-family:var(--font-display); font-weight:900; font-size:1.7rem; line-height:1;}
.percent-badge span{font-family:var(--font-display); font-weight:600; font-size:.56rem; letter-spacing:.1em; text-transform:uppercase; margin-top:2px;}
.hero-marquee{overflow:hidden; border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:13px 0; margin-top:clamp(22px,4vw,40px); background:var(--surface-1); flex:0 0 auto; width:100vw; margin-left:calc(50% - 50vw);}
.marquee-track{display:flex; width:max-content; animation:marqueeScroll 24s linear infinite;}
.marquee-track span{display:inline-flex; align-items:center; gap:.6em; padding-right:1.4em; font-family:var(--font-display); font-weight:700; font-size:clamp(.95rem,1.6vw,1.25rem); letter-spacing:.01em; text-transform:uppercase; color:var(--accent); white-space:nowrap;}
.marquee-track span::after{content:"✦"; font-size:.7em; color:var(--brand); opacity:.8;}
@keyframes marqueeScroll{from{transform:translateX(0)} to{transform:translateX(-50%)}}
@media(max-width:980px){ .photo-stack{max-width:340px; margin:0 auto;} .percent-badge{left:50%; transform:translateX(-190px);} }

/* slide type "video": full-bleed native-aspect video background, text overlaid on top,
   no frame, breaks out of the .wrap max-width to reach the true left/right edges */
.video-hero{position:relative; border-radius:0; overflow:hidden; flex:1 1 auto; min-height:clamp(320px,50dvh,600px); display:flex; align-items:flex-end; width:100vw; margin-left:calc(50% - 50vw);}
.video-hero-media{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block;}
.video-hero-scrim{position:absolute; inset:0; background:linear-gradient(0deg, rgba(8,8,10,.86) 0%, rgba(8,8,10,.5) 42%, rgba(8,8,10,.12) 75%);}
.video-hero::before, .video-hero::after{content:""; position:absolute; left:0; right:0; height:18%; z-index:0; pointer-events:none; backdrop-filter:blur(26px); -webkit-backdrop-filter:blur(26px);}
.video-hero::before{top:0; -webkit-mask-image:linear-gradient(to bottom, #000 0%, transparent 100%); mask-image:linear-gradient(to bottom, #000 0%, transparent 100%);}
.video-hero::after{bottom:0; -webkit-mask-image:linear-gradient(to top, #000 0%, transparent 100%); mask-image:linear-gradient(to top, #000 0%, transparent 100%);}
.video-hero-content{position:relative; z-index:1; padding:clamp(28px,5vw,56px) max(24px,calc((100vw - var(--maxw))/2 + 24px)); width:100%; color:#fff;}
.video-hero-content .eyebrow{color:#ff9db0;}
.video-hero-content .eyebrow::before{background:#fff;}
.video-hero-content .hero-slide-title{color:#fff; max-width:16ch;}
.video-hero-content .sub{color:rgba(255,255,255,.82); max-width:48ch;}
.video-hero-content .btn-ghost{color:#fff; border-color:rgba(255,255,255,.4);}
.video-hero-content .btn-ghost:hover{border-color:#fff; background:rgba(255,255,255,.12);}

.band{padding-top:clamp(64px,9vw,120px); padding-bottom:clamp(64px,9vw,120px);}
.band-line{border-top:1px solid var(--line);}

.manifesto p.big{font-family:var(--font-display); font-weight:300; letter-spacing:-.01em; font-size:clamp(1.5rem,3.6vw,2.7rem); line-height:1.18; max-width:26ch;}
.manifesto p.big em{font-style:normal; font-weight:800; color:var(--brand);}
.manifesto .note{font-family:var(--font-body); font-size:1.05rem; color:var(--ink-dim); max-width:52ch; margin-top:26px;}

.charity-grid{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:42px;}
.charity-card{border:1px solid var(--line); border-radius:22px; padding:34px; background:radial-gradient(130% 110% at 0% 0%, rgba(var(--brand-rgb),.16), transparent 58%), var(--bg-2);}
.charity-card .big{font-family:var(--font-display); font-weight:900; line-height:.95; font-size:clamp(3.2rem,8vw,5.4rem); color:var(--accent);}
.charity-card .lbl{margin-top:10px; color:var(--ink-dim); font-size:1.02rem;}
.charity-note{font-family:var(--font-display); font-weight:300; line-height:1.28; margin-top:36px; font-size:clamp(1.25rem,2.7vw,1.9rem); color:var(--ink); max-width:28ch;}
.charity-note b{font-weight:800; color:var(--brand);}
.vote-card{display:flex; justify-content:space-between; align-items:center; gap:18px; margin-top:26px; border:1px solid var(--line-strong); border-radius:18px; padding:22px 26px; text-decoration:none; color:var(--ink); background:radial-gradient(120% 160% at 100% 0%, rgba(86,194,198,.14), transparent 60%), var(--bg-2); transition:border-color .2s, transform .2s;}
.vote-card:hover{border-color:var(--donate); transform:translateY(-2px);}
.vote-card .vt b{color:var(--ink);}
.vote-cta{font-family:var(--font-display); font-weight:600; color:var(--donate); white-space:nowrap;}

/* filter tabs (gallery + catalog) */
.filter-tabs{display:flex; gap:10px; flex-wrap:wrap; margin-top:28px;}
.filter-tab{border:1px solid var(--line-strong); background:var(--bg-2); color:var(--ink-dim); padding:11px 17px; border-radius:999px; font-family:var(--font-display); font-weight:600; font-size:.86rem; cursor:pointer; transition:all .2s;}
.filter-tab[aria-selected="true"]{background:var(--ink); color:var(--bg); border-color:var(--ink);}

/* gallery */
.gallery-grid{column-count:4; column-gap:14px; margin-top:24px;}
.gallery-item{display:block; width:100%; padding:0; margin:0 0 14px; border:none; background:none; cursor:zoom-in; break-inside:avoid; border-radius:14px; overflow:hidden; position:relative;}
.gallery-item img{width:100%; display:block; border-radius:14px; transition:transform .4s var(--ease), filter .3s;}
.gallery-item:hover img{transform:scale(1.04); filter:brightness(1.06);}
.gallery-actions{display:flex; justify-content:center; margin-top:24px;}
.gallery-empty{color:var(--muted); margin-top:24px;}

/* lightbox */
.lightbox{position:fixed; inset:0; z-index:300; background:rgba(0,0,0,.93); display:flex; align-items:center; justify-content:center; padding:24px;}
.lightbox img{max-width:90vw; max-height:88vh; border-radius:8px; box-shadow:0 30px 80px rgba(0,0,0,.6);}
.lb-close{position:fixed; top:20px; right:24px; width:48px; height:48px; border-radius:50%; border:1px solid rgba(255,255,255,.25); background:rgba(0,0,0,.4); color:#fff; font-size:1.6rem; cursor:pointer;}
.lb-nav{position:fixed; top:50%; transform:translateY(-50%); width:54px; height:54px; border-radius:50%; border:1px solid rgba(255,255,255,.25); background:rgba(0,0,0,.4); color:#fff; font-size:2rem; cursor:pointer; line-height:1;}
.lb-prev{left:18px;} .lb-next{right:18px;}
.lb-close:hover,.lb-nav:hover{background:var(--brand); border-color:var(--brand);}
.lb-count{position:fixed; bottom:22px; left:50%; transform:translateX(-50%); color:#fff; font-family:var(--font-display); font-size:.9rem; opacity:.8;}

/* size guide */
.sg-link{font-family:var(--font-body); font-size:.75rem; font-weight:600; color:var(--accent); background:none; border:none; cursor:pointer; text-decoration:underline; text-underline-offset:2px; text-transform:none; letter-spacing:normal; margin-left:10px; padding:0;}
.sg-modal{position:fixed; inset:0; z-index:250; display:flex; align-items:center; justify-content:center; padding:20px;}
.sg-backdrop{position:absolute; inset:0; background:rgba(0,0,0,.6);}
.sg-card{position:relative; background:var(--bg-2); border:1px solid var(--line-strong); border-radius:20px; max-width:660px; width:100%; max-height:90dvh; overflow:auto; padding:26px; box-shadow:0 30px 80px rgba(0,0,0,.5);}
.sg-head{display:flex; justify-content:space-between; align-items:center; margin-bottom:20px;}
.sg-head h3{font-family:var(--font-display); font-weight:800; font-size:1.4rem; margin:0;}
.sg-close{background:none; border:none; color:var(--muted); font-size:1.7rem; line-height:1; cursor:pointer;}
.sg-close:hover{color:var(--ink);}
.sg-content{display:grid; grid-template-columns:190px 1fr; gap:26px; align-items:center;}
.sg-diagram{width:100%; height:auto; display:block;}
.sg-diagram text{font-family:var(--font-body); font-size:15px; font-weight:600;}
.sg-table{width:100%; border-collapse:collapse; font-variant-numeric:tabular-nums; font-size:.95rem;}
.sg-table th,.sg-table td{border:1px solid var(--line); padding:11px 8px; text-align:center;}
.sg-table thead th{font-family:var(--font-display); font-weight:800; color:var(--ink);}
.sg-table tbody th{text-align:left; font-weight:500; color:var(--ink-dim); white-space:nowrap;}
.sg-table td{color:var(--ink);}
.sg-note{color:var(--muted); font-size:.85rem; margin:14px 0 0; line-height:1.4;}
@media(max-width:560px){ .sg-content{grid-template-columns:1fr; gap:18px;} .sg-diagram-wrap{max-width:220px; margin:0 auto;} }

.feat-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:46px;}
.feat{border:1px solid var(--line); border-radius:18px; padding:24px; background:var(--bg-2);}
.feat .k{font-family:var(--font-display); font-weight:800; font-size:1.7rem; color:var(--ink);}
.feat .l{color:var(--muted); font-size:.92rem; margin-top:6px;}

/* products */
.products-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:28px;}
.product-card{border:1px solid var(--line); border-radius:20px; overflow:hidden; background:var(--bg-2); display:flex; flex-direction:column; transition:border-color .2s, transform .2s; cursor:pointer; text-decoration:none; color:inherit;}
.product-card:hover{border-color:var(--line-strong); transform:translateY(-3px);}
.pc-img{aspect-ratio:4/5; width:100%; object-fit:cover; display:block; background:var(--panel);}
.pc-body{padding:20px; display:flex; flex-direction:column; gap:8px; flex:1;}
.pc-top{display:flex; flex-wrap:wrap; justify-content:space-between; align-items:flex-start; gap:6px 10px;}
.pc-title{font-family:var(--font-display); font-weight:800; font-size:1.15rem; margin:0; line-height:1.1;}
.pc-sub{color:var(--muted); font-size:.82rem;}
.pc-mode{font-size:.72rem; font-weight:600; padding:5px 10px; border-radius:999px; white-space:nowrap; flex:none; color:var(--accent); border:1px solid rgba(var(--brand-rgb),.45);}
.pc-price{font-family:var(--font-display); font-weight:800; font-size:1.3rem; margin-top:auto; padding-top:6px;}
.pc-price small{font-size:.85rem; color:var(--muted); font-weight:400;}
.pc-btn{margin-top:8px; min-height:46px; padding:11px 20px; width:100%;}

/* carousel (product page + configurator) */
.tee-stage{border:1px solid var(--line); border-radius:24px; background:radial-gradient(80% 60% at 50% 12%, rgba(var(--brand-rgb),.14), transparent 60%), var(--bg-2); padding:18px; overflow:hidden;}
.carousel{position:relative;}
.prod-photo{width:100%; height:auto; display:block; border-radius:16px; aspect-ratio:4/5; object-fit:cover; cursor:zoom-in; background:var(--panel);}
.car-nav{position:absolute; top:50%; transform:translateY(-50%); width:42px; height:42px; border-radius:50%; border:1px solid var(--line-strong); background:var(--bg-2); color:var(--ink); font-size:1.5rem; line-height:1; cursor:pointer; opacity:.9; transition:opacity .2s, background .2s, color .2s;}
.car-nav:hover{opacity:1; background:var(--brand); color:#fff; border-color:var(--brand);}
.car-prev{left:10px;} .car-next{right:10px;}
.car-dots{display:flex; gap:7px; justify-content:center; margin-top:14px;}
.car-dots button{width:8px; height:8px; border-radius:50%; border:none; background:var(--line-strong); cursor:pointer; padding:0; transition:background .2s, transform .2s;}
.car-dots button[aria-current="true"]{background:var(--brand); transform:scale(1.3);}
.tee-foot{display:flex; align-items:center; justify-content:space-between; padding:14px 8px 2px; color:var(--muted); font-size:.85rem;}
svg.tee{width:100%; height:auto; display:block; filter:drop-shadow(0 24px 50px rgba(0,0,0,.5));}
[hidden]{display:none !important;}

/* product page */
.breadcrumb{display:flex; gap:8px; align-items:center; color:var(--muted); font-size:.9rem; padding:26px 0 0;}
.breadcrumb a{color:var(--ink-dim); text-decoration:none;}
.breadcrumb a:hover{color:var(--ink);}
.product-page{display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; padding:24px 0 40px;}
.pp-gallery{position:sticky; top:96px;}
.pp-title{font-family:var(--font-display); font-weight:900; letter-spacing:-.02em; font-size:clamp(2rem,4vw,3rem); line-height:1; margin:.2em 0 .1em;}
.pp-sub{color:var(--ink-dim);}
.pp-price{font-family:var(--font-display); font-weight:800; font-size:2rem; margin:18px 0 6px;}
.pp-price small{font-size:1rem; color:var(--muted); font-weight:400;}
.pp-charity{font-size:.9rem; color:var(--donate); display:flex; align-items:center; gap:7px; margin-bottom:24px;}
.pp-charity svg{width:15px; height:15px;}

.field{margin-bottom:22px;}
.field > label.lab{display:block; font-family:var(--font-display); font-weight:600; font-size:.84rem; letter-spacing:.04em; text-transform:uppercase; color:var(--ink); margin-bottom:11px;}
.field .req{color:var(--brand);}
.swatches{display:flex; gap:12px; flex-wrap:wrap;}
.swatch{position:relative; cursor:pointer;}
.swatch input{position:absolute; opacity:0; inset:0; cursor:pointer;}
.swatch .dot{width:54px; height:54px; border-radius:14px; border:2px solid var(--line-strong); display:grid; place-items:center; transition:transform .18s var(--ease), border-color .2s;}
.swatch .nm{display:block; text-align:center; font-size:.82rem; color:var(--ink-dim); margin-top:8px;}
.swatch input:focus-visible + .dot{outline:3px solid var(--brand-soft); outline-offset:3px;}
.swatch input:checked + .dot{border-color:var(--brand); transform:scale(1.06);}
.swatch input:checked ~ .nm{color:var(--ink);}
.dot .tick{width:18px; height:18px; opacity:0; transition:opacity .15s;}
.swatch input:checked + .dot .tick{opacity:1;}
.sizes{display:flex; flex-wrap:wrap; gap:10px;}
.size{position:relative;}
.size input{position:absolute; opacity:0; inset:0; cursor:pointer;}
.size span{display:grid; place-items:center; min-width:52px; height:52px; padding:0 8px; border:1px solid var(--line-strong); border-radius:13px; font-family:var(--font-display); font-weight:600; cursor:pointer; transition:all .18s var(--ease); color:var(--ink-dim);}
.size input:focus-visible + span{outline:3px solid var(--brand-soft); outline-offset:2px;}
.size input:checked + span{background:var(--ink); color:var(--bg); border-color:var(--ink); transform:translateY(-2px);}
.qty{display:inline-flex; align-items:center; border:1px solid var(--line-strong); border-radius:13px; overflow:hidden;}
.qty button{width:50px; height:50px; background:transparent; border:none; color:var(--ink); font-size:1.4rem; cursor:pointer; transition:background .15s;}
.qty button:hover{background:var(--surface-hover);}
.qty input{width:54px; height:50px; text-align:center; background:transparent; border:none; color:var(--ink); font-family:var(--font-display); font-weight:600; font-size:1.05rem; -moz-appearance:textfield;}
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.text-in{width:100%; background:var(--bg); border:1px solid var(--line-strong); color:var(--ink); font-family:var(--font-body); font-size:1rem; padding:14px 16px; border-radius:13px; transition:border-color .2s;}
.text-in::placeholder{color:var(--muted);}
.text-in:focus{outline:none; border-color:var(--brand);}
textarea.text-in{resize:vertical; min-height:80px;}
.custom-note{border:1px solid var(--line); border-radius:14px; padding:16px 18px; background:var(--bg-2); font-size:.92rem; color:var(--ink-dim);}
.custom-note > b{display:block; font-family:var(--font-display); color:var(--ink); margin-bottom:4px;}
.check{display:flex; gap:13px; align-items:flex-start; cursor:pointer; padding:14px; margin-top:12px; border-radius:12px; background:var(--surface-1); transition:background .2s;}
.check:hover{background:var(--surface-hover);}
.check input{margin-top:2px; width:20px; height:20px; accent-color:var(--brand); cursor:pointer; flex:none;}
.check .ct{font-size:.92rem; color:var(--ink-dim);}
.check .ct b{color:var(--accent); font-weight:700;}

/* cart drawer */
.drawer-overlay{position:fixed; inset:0; background:rgba(0,0,0,.55); z-index:200; opacity:0; pointer-events:none; transition:opacity .3s;}
.drawer-overlay.open{opacity:1; pointer-events:auto;}
.drawer{position:fixed; top:0; right:0; height:100dvh; width:min(440px,94vw); background:var(--bg-2); border-left:1px solid var(--line); z-index:210; transform:translateX(101%); transition:transform .35s var(--ease); display:flex; flex-direction:column; box-shadow:-20px 0 60px rgba(0,0,0,.4);}
.drawer.open{transform:none;}
.drawer-head{display:flex; align-items:center; justify-content:space-between; padding:22px 24px; border-bottom:1px solid var(--line);}
.drawer-head h3{font-family:var(--font-display); font-weight:800; font-size:1.3rem; margin:0;}
.drawer-close{background:none; border:none; color:var(--muted); font-size:1.6rem; cursor:pointer; line-height:1;}
.drawer-close:hover{color:var(--ink);}
.drawer-body{flex:1; overflow-y:auto; padding:8px 24px;}
.drawer-foot{border-top:1px solid var(--line); padding:20px 24px calc(20px + env(safe-area-inset-bottom));}
.cart-item{display:flex; align-items:center; gap:14px; padding:16px 0; border-bottom:1px solid var(--line);}
.cart-item img{width:52px; height:66px; object-fit:cover; border-radius:10px; flex:none; background:var(--panel);}
.ci-info{flex:1; min-width:0;}
.ci-info b{font-family:var(--font-display); font-weight:600; font-size:.95rem; display:block;}
.ci-info span{color:var(--muted); font-size:.82rem;}
.ci-qty{display:inline-flex; align-items:center; border:1px solid var(--line-strong); border-radius:10px; overflow:hidden; flex:none;}
.ci-qty button{width:32px; height:32px; background:transparent; border:none; color:var(--ink); cursor:pointer; font-size:1.1rem;}
.ci-qty span{min-width:24px; text-align:center; font-variant-numeric:tabular-nums;}
.ci-price{font-family:var(--font-display); font-weight:700; text-align:right; font-variant-numeric:tabular-nums; font-size:.9rem;}
.ci-remove{background:none; border:none; color:var(--muted); font-size:1.2rem; cursor:pointer; flex:none; line-height:1;}
.ci-remove:hover{color:var(--brand);}
@media(max-width:480px){
  .cart-item{flex-wrap:wrap; row-gap:10px;}
  .ci-info{flex:1 1 200px;}
  .ci-price{margin-left:auto;}
}
.cart-empty{color:var(--muted); text-align:center; padding:48px 0;}
.cart-total{display:flex; justify-content:space-between; align-items:baseline; margin-bottom:4px;}
.cart-total .tv{font-family:var(--font-display); font-weight:800; font-size:1.6rem; font-variant-numeric:tabular-nums;}
.charity-line{font-size:.82rem; color:var(--donate); margin:0 0 14px; display:flex; align-items:center; gap:7px;}
.charity-line svg{width:14px; height:14px; flex:none;}
.cart-fields{display:grid; gap:10px; margin-bottom:14px;}
.cart-fields .text-in{padding:11px 14px;}
.hint{font-size:.8rem; color:var(--muted); margin-top:12px; text-align:center;}
.hint a{color:var(--accent); text-decoration:underline; text-underline-offset:2px;}

/* process / care */
.steps{display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:48px;}
.step{border:1px solid var(--line); border-radius:18px; padding:26px 22px; background:var(--bg-2); position:relative; overflow:hidden;}
.step .n{font-family:var(--font-display); font-weight:900; font-size:3.4rem; line-height:1; color:transparent; -webkit-text-stroke:1.4px var(--brand); opacity:.85;}
.step h3{font-family:var(--font-display); font-weight:700; font-size:1.12rem; margin:16px 0 8px; overflow-wrap:break-word;}
.step p{color:var(--ink-dim); font-size:.95rem; margin:0;}
.care-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:46px;}
.care{border:1px solid var(--line); border-radius:18px; padding:24px; background:var(--bg-2); display:flex; flex-direction:column; gap:14px;}
.care svg{width:34px; height:34px; color:var(--accent);}
.care h4{font-family:var(--font-display); font-weight:600; font-size:1rem; margin:0;}
.care p{margin:0; color:var(--muted); font-size:.9rem;}

/* footer */
footer{border-top:1px solid var(--line); padding:64px 0 40px; margin-top:40px;}
.foot-grid{display:flex; flex-wrap:wrap; gap:40px; justify-content:space-between; align-items:flex-start;}
.foot-brand{max-width:34ch;}
.foot-brand p{color:var(--muted); font-size:.95rem; margin:14px 0 0;}
.foot-tag{font-family:var(--font-display); font-weight:300; color:var(--ink-dim); font-size:1.05rem; margin-top:18px; line-height:1.35;}
.foot-col h5{font-family:var(--font-display); font-weight:600; font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin:0 0 16px;}
.foot-col a{display:block; color:var(--ink-dim); text-decoration:none; margin-bottom:10px; transition:color .2s;}
.foot-col a:hover{color:var(--accent);}
.socials{display:flex; gap:12px; flex-wrap:wrap; margin-top:6px;}
.socials .social{display:inline-flex; align-items:center; gap:8px; margin:0; border:1px solid var(--line-strong); border-radius:999px; padding:10px 15px; color:var(--ink-dim); text-decoration:none; font-size:.88rem; line-height:1; transition:all .2s;}
.socials .social:hover{color:var(--ink); border-color:var(--ink); transform:translateY(-2px);}
.socials .social svg{width:17px; height:17px; flex:0 0 auto; display:block;}
.foot-bottom{margin-top:50px; padding-top:24px; border-top:1px solid var(--line); display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; color:var(--muted); font-size:.85rem;}
.foot-legal{display:flex; gap:16px; flex-wrap:wrap;}
.foot-legal a{color:var(--muted); text-decoration:none;}
.foot-legal a:hover{color:var(--ink-dim); text-decoration:underline;}

/* payment return banner */
.payback{display:none; background:var(--bg-2); border-bottom:1px solid var(--line);}
.payback.show{display:block;}
.payback-inner{display:flex; align-items:center; gap:14px; padding:16px 24px;}
.payback-dot{width:11px; height:11px; border-radius:50%; background:var(--brand-soft); flex:none; animation:pulse 1.2s ease-in-out infinite;}
.payback #paybackText{font-weight:500; color:var(--ink);}
.payback.ok{background:rgba(86,194,198,.12); border-color:rgba(86,194,198,.45);}
.payback.ok .payback-dot{background:var(--teal); animation:none;}
.payback.err{background:rgba(var(--brand-rgb),.14); border-color:rgba(var(--brand-rgb),.45);}
.payback.err .payback-dot{background:var(--brand); animation:none;}
.payback-x{margin-left:auto; background:none; border:none; color:var(--muted); font-size:1.6rem; line-height:1; cursor:pointer; padding:0 4px;}
@keyframes pulse{50%{opacity:.25}}

.toast{position:fixed; left:50%; bottom:28px; transform:translate(-50%,calc(100% + 60px)); background:var(--teal); color:#04201f; padding:15px 22px; border-radius:14px; z-index:400; font-weight:600; box-shadow:0 18px 50px rgba(0,0,0,.5); transition:transform .4s var(--ease); max-width:92vw;}
.toast.show{transform:translate(-50%,0);}

.rv{opacity:0; animation:rise .9s var(--ease) both; animation-delay:var(--d,0s);}
@keyframes rise{from{opacity:0; transform:translateY(30px)} to{opacity:1; transform:none}}
.blob-bg, .hero-visual{animation:blobIn 1.1s var(--ease) both; animation-delay:.25s;}
@keyframes blobIn{from{opacity:0; transform:scale(.86) rotate(-5deg)} to{opacity:1; transform:none}}
.sticker{animation:spin 26s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}
.float{animation:floaty 6s ease-in-out infinite;}
@keyframes floaty{50%{transform:translateY(-12px) rotate(-4deg)}}
.obs{opacity:0; transform:translateY(34px); transition:opacity .8s var(--ease), transform .8s var(--ease);}
.obs.in{opacity:1; transform:none;}

@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr; gap:36px;}
  .hero-visual{max-width:380px; margin:0 auto;}
  .product-page{grid-template-columns:1fr; gap:28px;}
  .pp-gallery{position:relative; top:0; max-width:440px; margin:0 auto; width:100%;}
  .feat-grid{grid-template-columns:repeat(2,1fr);}
  .steps{grid-template-columns:repeat(2,1fr);}
  .care-grid{grid-template-columns:repeat(2,1fr);}
  .products-grid{grid-template-columns:repeat(2,1fr);}
  .gallery-grid{column-count:3;}
  .nav-links{display:none;}
  .nav-links.open{display:flex; position:absolute; top:68px; left:0; right:0; flex-direction:column; gap:0; background:var(--bg-2); border-bottom:1px solid var(--line); padding:8px 24px 18px;}
  .nav-links.open a{padding:14px 0; border-bottom:1px solid var(--line);}
  .nav-links.open .btn{margin-top:14px;}
  .burger{display:grid; place-items:center;}
  .vote-card{flex-direction:column; align-items:flex-start; gap:12px;}
}
@media (max-width:560px){
  .feat-grid,.steps,.care-grid{grid-template-columns:1fr 1fr;}
  .charity-grid{grid-template-columns:1fr;}
  .products-grid{grid-template-columns:1fr 1fr;}
  .gallery-grid{column-count:2; column-gap:10px;}
  .price-tag,.sticker{transform:scale(.85);}
  .wrap{padding:0 18px;}

  /* compact mobile hero: smaller type scale + tighter spacing so the primary CTA
     sits closer to the top instead of requiring a long scroll to reach it.
     All hero_slides share one grid cell sized to the tallest slide (see the
     equal-height grid-stack rule above) — on mobile that's always slide 0
     (copy + visual stacked in one column), so trimming ITS height is what
     actually controls how tall the video/philosophy slides render too. */
  .hero{padding-top:20px; padding-bottom:32px;}
  .hero-grid{gap:20px;}
  .hero h1{font-size:clamp(2.2rem,10vw,2.9rem); line-height:.92; margin:0 0 .16em;}
  .hero h1 .thin{margin-bottom:.3em;}
  .hero p.sub{font-size:1rem; margin:0 0 14px;}
  .hero-actions{gap:10px;}
  .hero-actions .btn{padding:13px 20px; font-size:.92rem; min-height:46px;}
  .spec-row{margin-top:14px; gap:8px;}
  .chip{font-size:.76rem; padding:7px 12px;}
  .hero-visual{max-width:210px;}
  .hero-slide-title{font-size:clamp(1.9rem,9vw,2.6rem);}
  .hero-slide .sub{font-size:.95rem;}

  /* video slide: was forcing a hard 420px min-height (>50% of a phone viewport)
     regardless of screen height — cap it relative to viewport height instead so
     the CTA button underneath doesn't sit an extra scroll below the fold. */
  .video-hero{min-height:min(50dvh,360px);}
  .video-hero-content{padding:18px max(18px,calc((100vw - var(--maxw))/2 + 18px));}

  /* section rhythm: the same clamp(64px,9vw,120px) floor repeated on every band
     adds up to a very long, sparse-feeling scroll on narrow phones. */
  .band{padding-top:36px; padding-bottom:36px;}
}
@media (prefers-reduced-motion:reduce){ *{animation:none !important; transition:none !important; scroll-behavior:auto !important;} .rv,.obs{opacity:1 !important; transform:none !important;} .blob-photo img{transition:opacity .01s !important;} }
:focus-visible{outline:3px solid var(--brand-soft); outline-offset:2px; border-radius:4px;}
