/* ==========================================================================
   CG PREMIUM v12 — design system
   Ink dark · Space Grotesk / Inter / JetBrains Mono · #FB5607 accent
   Signature: the Edition Plate (№ serial · EDITION 1/1 / ARCHIVED)
   NOTE: checkout styles are strictly scoped — payment gateway containers
   are NEVER targeted or hidden by this stylesheet.
   ========================================================================== */

:root{
  --ink:#0A0A0B;
  --panel:#131315;
  --panel-2:#18181B;
  --line:rgba(255,255,255,.08);
  --line-strong:rgba(255,255,255,.14);
  --text:#F6F5F3;
  --muted:#A2A099;
  --faint:#6E6C66;
  --accent:#FB5607;
  --accent-2:#FF7A33;
  --accent-soft:rgba(251,86,7,.13);
  --foil:#C9A96E;             /* edition plate gold */
  --archived:#E5484D;
  --success:#35D07F;
  --display:'Space Grotesk',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --r-lg:20px;
  --r-md:14px;
  --r-sm:10px;
  --shadow-1:0 8px 30px rgba(0,0,0,.35);
  --shadow-2:0 20px 60px rgba(0,0,0,.5);
  --wrap:1200px;
  --ease:cubic-bezier(.22,.8,.28,1);
}

/* ---------- Reset & base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;background:var(--ink);color:var(--text);
  font-family:var(--body);font-size:16px;line-height:1.65;
  font-weight:400;-webkit-font-smoothing:antialiased;
}
img,video{max-width:100%;height:auto;display:block}
a{color:var(--text);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--accent-2)}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;letter-spacing:-.02em;line-height:1.12;margin:0 0 .5em;text-wrap:balance}
p{margin:0 0 1em}
::selection{background:var(--accent);color:#fff}

:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}

.cgp-skip{position:absolute;left:-9999px;top:0;background:var(--accent);color:#fff;padding:10px 18px;z-index:999;border-radius:0 0 10px 0}
.cgp-skip:focus{left:0}

.cgp-wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px}
.cgp-wrap--narrow{max-width:820px}
.cgp-sec{padding:120px 0}
/* Skip painting offscreen sections until they're scrolled near the viewport. */
.cgp-sec,.cgp-stats,.cgp-logos{content-visibility:auto;contain-intrinsic-size:1px 600px}
.cgp-sec__head{max-width:640px;margin-bottom:56px}
.cgp-sec__title{font-size:clamp(30px,4.4vw,48px)}
.cgp-sec__lead{color:var(--muted);font-size:17px;max-width:52ch}
.cgp-sec__more{margin-top:48px;text-align:center}
.cgp-eyebrow{
  font-family:var(--mono);font-size:11.5px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent);
  margin:0 0 14px;
}

/* ---------- Signature: Edition Plate ---------- */
.cgp-plate{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10.5px;font-weight:500;
  letter-spacing:.14em;padding:6px 12px;border-radius:999px;
  border:1px solid rgba(201,169,110,.35);
  color:var(--foil);
  background:linear-gradient(100deg,rgba(201,169,110,.12),rgba(201,169,110,.03) 55%,rgba(201,169,110,.10));
  white-space:nowrap;
}
.cgp-plate__sep{width:3px;height:3px;border-radius:50%;background:currentColor;opacity:.55}
.cgp-plate.is-archived{
  border-color:rgba(229,72,77,.4);color:var(--archived);
  background:rgba(229,72,77,.08);animation:none;
}
.cgp-plate--single{font-size:11.5px;padding:8px 16px;margin-bottom:18px}
.cgp-plate--mini{font-size:9.5px;padding:5px 10px}

/* ---------- Buttons ---------- */
.cgp-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--display);font-weight:600;font-size:15px;letter-spacing:.01em;
  padding:13px 26px;border-radius:999px;border:1px solid transparent;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s,border-color .2s,color .2s;
  will-change:transform;
}
.cgp-btn--lg{padding:16px 32px;font-size:16px}
.cgp-btn--primary{
  background:linear-gradient(135deg,var(--accent),#E14A00);color:#fff;
  box-shadow:0 6px 24px rgba(251,86,7,.35);
}
.cgp-btn--primary:hover{color:#fff;transform:translateY(-2px);box-shadow:0 10px 32px rgba(251,86,7,.5)}
.cgp-btn--primary:active{transform:translateY(0)}
.cgp-btn--ghost{border-color:var(--line-strong);color:var(--text);background:rgba(255,255,255,.02)}
.cgp-btn--ghost:hover{border-color:var(--accent);color:var(--accent-2);transform:translateY(-2px)}
.cgp-btn[disabled]{opacity:.55;pointer-events:none}
.cgp-ic{display:inline-flex;width:18px;height:18px}
.cgp-ic svg{width:100%;height:100%}

/* ---------- Announcement ---------- */
.cgp-announce{background:linear-gradient(90deg,rgba(251,86,7,.16),rgba(251,86,7,.05));border-bottom:1px solid var(--line)}
.cgp-announce a{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:9px 20px;font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--text);
}
.cgp-announce__dot{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse 2.2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(251,86,7,.5)}55%{box-shadow:0 0 0 7px rgba(251,86,7,0)}}

/* ---------- Header ---------- */
.cgp-header{
  position:sticky;top:0;z-index:90;
  background:rgba(10,10,11,.9);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s;
  transform:translateZ(0);
}
.cgp-header.is-scrolled{box-shadow:var(--shadow-1)}
.cgp-header__in{max-width:var(--wrap);margin:0 auto;padding:0 28px;display:flex;align-items:center;gap:34px;height:76px}
.cgp-logo{display:flex;align-items:center}
.cgp-logo__img{max-height:40px;width:auto}
.cgp-logo__word{font-family:var(--display);font-weight:700;font-size:20px;letter-spacing:-.01em}
.cgp-logo__word span{color:var(--accent)}
.cgp-nav{flex:1}
.cgp-nav__list{display:flex;gap:30px;list-style:none;margin:0;padding:0}
.cgp-nav__list a{font-size:14.5px;font-weight:500;color:var(--muted);position:relative;padding:6px 0}
.cgp-nav__list a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--accent);border-radius:2px;transition:width .28s var(--ease)}
.cgp-nav__list a:hover{color:var(--text)}
.cgp-nav__list a:hover::after{width:100%}
.cgp-header__tools{display:flex;align-items:center;gap:6px}
.cgp-tool{position:relative;display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;color:var(--muted);transition:color .2s,background .2s}
.cgp-tool:hover{color:var(--text);background:rgba(255,255,255,.06)}
.cgp-cart-count,.cgp-wish-count{
  position:absolute;top:2px;right:0;min-width:17px;height:17px;padding:0 4px;
  border-radius:999px;background:var(--panel-2);border:1px solid var(--line-strong);
  font-family:var(--mono);font-size:10px;line-height:15px;text-align:center;color:var(--muted);
  transition:background .2s,color .2s;
}
.cgp-cart-count.has-items,.cgp-wish-count.has-items{background:var(--accent);border-color:var(--accent);color:#fff}
.cgp-header__cta{margin-left:10px;padding:11px 22px;font-size:14px}
.cgp-burger{display:none}

/* ---------- Mobile menu ---------- */
.cgp-mobile{position:fixed;inset:0;z-index:120;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);display:none}
.cgp-mobile.is-open{display:block}
.cgp-mobile[hidden]{display:none !important}
.cgp-mobile__panel{
  position:absolute;top:0;right:0;bottom:0;width:min(360px,88vw);
  background:var(--panel);border-left:1px solid var(--line);
  padding:70px 30px 40px;display:flex;flex-direction:column;gap:8px;
  transform:translateX(100%);transition:transform .35s var(--ease);
}
.cgp-mobile.is-open .cgp-mobile__panel{transform:translateX(0)}
.cgp-mobile__close{position:absolute;top:16px;right:16px;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--muted)}
.cgp-mobile__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}
.cgp-mobile__list a{display:block;padding:13px 4px;font-family:var(--display);font-size:21px;font-weight:600;border-bottom:1px solid var(--line)}
.cgp-mobile__cta{margin-top:auto}

/* ---------- Overlays (search / wishlist / quickview) ----------
   Closed by default. Visibility is driven by the .is-open class and the
   [hidden] attribute, never by a bare display:flex (which would ignore hidden). */
.cgp-overlay{position:fixed;inset:0;z-index:130;background:rgba(5,5,6,.72);backdrop-filter:blur(10px);align-items:flex-start;justify-content:center;padding:9vh 20px 40px;overflow-y:auto;display:none}
.cgp-overlay.is-open{display:flex}
.cgp-overlay[hidden]{display:none !important}
.cgp-overlay__panel{
  position:relative;width:min(620px,100%);
  background:var(--panel);border:1px solid var(--line-strong);border-radius:var(--r-lg);
  padding:40px;box-shadow:var(--shadow-2);
  animation:overlayIn .3s var(--ease);
}
.cgp-overlay__panel--wide{width:min(940px,100%)}
@keyframes overlayIn{from{opacity:0;transform:translateY(14px) scale(.985)}to{opacity:1;transform:none}}
.cgp-overlay__close{position:absolute;top:14px;right:14px;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--muted)}
.cgp-overlay__close:hover{color:var(--text);background:rgba(255,255,255,.06)}
.cgp-overlay__title{font-size:26px;margin-bottom:4px}
.cgp-overlay__sub{color:var(--muted);font-size:14px;margin-bottom:24px}
.cgp-search-form{display:flex;align-items:center;gap:14px;border:1px solid var(--line-strong);border-radius:999px;padding:6px 8px 6px 20px;color:var(--muted)}
.cgp-search-form:focus-within{border-color:var(--accent)}
.cgp-search-form input{flex:1;background:none;border:0;color:var(--text);font-size:17px;padding:10px 0;outline:none}
.cgp-search-results{margin-top:22px;display:flex;flex-direction:column;gap:6px}
.cgp-search-results a{display:flex;align-items:center;gap:14px;padding:10px;border-radius:var(--r-md)}
.cgp-search-results a:hover{background:rgba(255,255,255,.04)}
.cgp-search-results img{width:52px;height:52px;object-fit:cover;border-radius:8px}
.cgp-search-results .price{margin-left:auto;font-family:var(--mono);font-size:13px;color:var(--muted)}

/* ---------- Hero ---------- */
.cgp-hero{position:relative;overflow:hidden;padding:110px 0 90px}
.cgp-hero__bg{position:absolute;inset:0;pointer-events:none}
.cgp-hero__glow{
  position:absolute;top:-260px;right:-180px;width:760px;height:760px;border-radius:50%;
  background:radial-gradient(circle,rgba(251,86,7,.16),transparent 62%);
  animation:glowDrift 14s ease-in-out infinite alternate;
}
@keyframes glowDrift{from{transform:translate(0,0)}to{transform:translate(-70px,50px)}}
.cgp-hero__grain{position:absolute;inset:0;opacity:.5;background-image:radial-gradient(rgba(255,255,255,.028) 1px,transparent 1px);background-size:26px 26px}
.cgp-hero__in{position:relative;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:60px;align-items:center}
.cgp-hero__title{
  font-size:clamp(38px,5.6vw,66px);
  animation:heroRise .8s var(--ease) both;
}
.cgp-hero__eyebrow{animation:heroRise .8s var(--ease) both}
.cgp-hero__sub{color:var(--muted);font-size:18px;max-width:50ch;animation:heroRise .8s .12s var(--ease) both}
.cgp-hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin:32px 0 18px;animation:heroRise .8s .22s var(--ease) both}
.cgp-hero__note{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);animation:heroRise .8s .32s var(--ease) both}
@keyframes heroRise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* Hero cover wall: two-column vertical drift */
.cgp-hero__wall{position:relative;height:540px;overflow:hidden;border-radius:var(--r-lg);
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 12%,#000 88%,transparent);
  mask-image:linear-gradient(180deg,transparent,#000 12%,#000 88%,transparent);
}
.cgp-wall__track{display:grid;grid-template-columns:1fr 1fr;gap:18px;animation:wallDrift 60s linear infinite;will-change:transform;backface-visibility:hidden}
.cgp-hero__wall:hover .cgp-wall__track{animation-play-state:paused}
@keyframes wallDrift{from{transform:translateY(0)}to{transform:translateY(-50%)}}
.cgp-wall__item{position:relative;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--line)}
.cgp-wall__item:nth-child(even){transform:translateY(46px)}
.cgp-wall__item img{width:100%;aspect-ratio:1;object-fit:cover}
.cgp-wall__plate{
  position:absolute;left:10px;bottom:10px;padding:4px 9px;border-radius:999px;
  font-family:var(--mono);font-size:9px;letter-spacing:.12em;color:var(--foil);
  background:rgba(10,10,11,.72);border:1px solid rgba(201,169,110,.3);backdrop-filter:blur(4px);
}

/* ---------- Logos marquee ---------- */
.cgp-logos{border-block:1px solid var(--line);padding:22px 0;overflow:hidden}
.cgp-logos__track{display:flex;gap:64px;width:max-content;animation:marquee 34s linear infinite;will-change:transform;backface-visibility:hidden}
.cgp-logos:hover .cgp-logos__track{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.cgp-logos__item{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);white-space:nowrap}

/* ---------- Stats ---------- */
.cgp-stats{padding:90px 0}
.cgp-stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.cgp-stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:34px 30px;transition:transform .3s var(--ease),border-color .3s}
.cgp-stat:hover{transform:translateY(-4px);border-color:var(--line-strong)}
.cgp-stat__num{display:block;font-family:var(--display);font-weight:700;font-size:clamp(30px,3.4vw,44px);letter-spacing:-.02em;color:var(--text)}
.cgp-stat__label{font-size:13.5px;color:var(--muted)}

/* ---------- Product grid & cards ---------- */
.cgp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.cgp-card{
  position:relative;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--r-lg);overflow:hidden;
  transition:transform .35s var(--ease),border-color .3s,box-shadow .35s var(--ease);
}
.cgp-card:hover{transform:translateY(-6px);border-color:var(--line-strong);box-shadow:var(--shadow-1)}
.cgp-card__media{position:relative;display:block;aspect-ratio:1;overflow:hidden;background:var(--panel-2)}
.cgp-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.cgp-card:hover .cgp-card__media img{transform:scale(1.045)}
.cgp-card__media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .35s}
.cgp-card:hover .cgp-card__media video{opacity:1}
.cgp-card__noimg{display:block;width:100%;height:100%;background:linear-gradient(135deg,var(--panel-2),var(--panel))}
.cgp-card__labels{position:absolute;top:12px;left:12px;display:flex;flex-wrap:wrap;gap:6px;z-index:2}
.cgp-label{
  display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:999px;
  font-family:var(--mono);font-size:9.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  background:rgba(10,10,11,.78);backdrop-filter:blur(4px);border:1px solid var(--line-strong);color:var(--text);
}
.cgp-label .cgp-ic{width:11px;height:11px}
.cgp-label--featured{color:var(--foil);border-color:rgba(201,169,110,.4)}
.cgp-label--best{color:var(--accent-2);border-color:rgba(251,86,7,.45)}
.cgp-label--sale{background:var(--accent);border-color:var(--accent);color:#fff}
.cgp-label--motion{color:var(--success);border-color:rgba(53,208,127,.4)}
.cgp-label--archived{color:var(--archived);border-color:rgba(229,72,77,.45)}
.cgp-card__seal{
  position:absolute;inset:auto 0 0;padding:10px;text-align:center;z-index:2;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.3em;color:var(--archived);
  background:linear-gradient(0deg,rgba(10,10,11,.9),transparent);
}
.cgp-card.is-archived .cgp-card__media img{filter:grayscale(.55) brightness(.75)}
.cgp-card__seal--big{font-size:13px;padding:18px}
.cgp-card__actions{
  position:absolute;top:12px;right:12px;z-index:3;display:flex;flex-direction:column;gap:8px;
  opacity:0;transform:translateX(8px);transition:opacity .28s,transform .28s var(--ease);
}
.cgp-card:hover .cgp-card__actions,.cgp-card__actions:focus-within{opacity:1;transform:none}
.cgp-card__act{
  width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(10,10,11,.82);backdrop-filter:blur(4px);border:1px solid var(--line-strong);color:var(--muted);
  transition:color .2s,border-color .2s,transform .2s;
}
.cgp-card__act:hover{color:var(--text);border-color:var(--accent);transform:scale(1.06)}
.cgp-card__act.is-on{color:var(--accent);border-color:var(--accent)}
.cgp-card__body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:10px}
.cgp-card__title{font-size:16.5px;margin:0;font-weight:600}
.cgp-card__title a:hover{color:var(--accent-2)}
.cgp-card__row{display:flex;align-items:center;justify-content:space-between}
.cgp-card__price{font-family:var(--mono);font-size:15px;font-weight:500}
.cgp-card__price del{color:var(--faint);margin-right:8px;font-size:12.5px}
.cgp-card__price ins{text-decoration:none;color:var(--accent-2)}
.cgp-card__gone{color:var(--faint);font-size:13px}
.cgp-card__go{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid var(--line-strong);color:var(--muted);transition:all .25s var(--ease)}
.cgp-card__go:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(-38deg)}

/* ---------- Skeletons ---------- */
.cgp-shop-skeletons{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:22px}
.cgp-skel-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;padding-bottom:18px}
.cgp-skel-card__img{aspect-ratio:1}
.cgp-skel-card__line{height:13px;border-radius:6px;margin:14px 20px 0}
.cgp-skel-card__line--short{width:45%}
.cgp-skel-card__img,.cgp-skel-card__line{
  background:linear-gradient(90deg,var(--panel-2) 25%,#202024 40%,var(--panel-2) 60%);
  background-size:200% 100%;animation:shimmer 1.3s infinite;
}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}

/* ---------- Shop page ---------- */
.cgp-shop-page{padding:60px 0 120px}
.cgp-shop-head{margin:26px 0 36px}
.cgp-shop-head__title{font-size:clamp(34px,5vw,56px)}
.cgp-shop-head__sub{color:var(--muted);font-size:17px;max-width:56ch}
.cgp-shop-bar{
  position:sticky;top:76px;z-index:40;
  display:flex;flex-wrap:wrap;align-items:center;gap:14px;
  background:rgba(10,10,11,.85);backdrop-filter:blur(14px);
  border:1px solid var(--line);border-radius:var(--r-lg);
  padding:14px 18px;margin-bottom:20px;
}
.cgp-shop-bar__search{display:flex;align-items:center;gap:10px;color:var(--faint);border:1px solid var(--line-strong);border-radius:999px;padding:4px 6px 4px 16px;min-width:230px}
.cgp-shop-bar__search:focus-within{border-color:var(--accent)}
.cgp-shop-bar__search input{background:none;border:0;color:var(--text);padding:8px 0;font-size:14.5px;outline:none;width:100%}
.cgp-shop-bar__filters{display:flex;flex-wrap:wrap;gap:8px;flex:1}
.cgp-chip{
  padding:9px 18px;border-radius:999px;border:1px solid var(--line-strong);
  font-size:13.5px;font-weight:500;color:var(--muted);
  transition:all .22s var(--ease);
}
.cgp-chip:hover{color:var(--text);border-color:var(--accent)}
.cgp-chip.is-active{background:var(--accent);border-color:var(--accent);color:#fff}
.cgp-shop-bar__right{display:flex;gap:10px}
.cgp-shop-bar select{
  background:var(--panel-2);border:1px solid var(--line-strong);border-radius:999px;
  color:var(--text);font-size:13.5px;padding:9px 16px;outline:none;
}
.cgp-shop-count{font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--faint);margin:0 0 20px;min-height:1.2em}
.cgp-shop-sentinel{height:1px}
.cgp-shop-empty{grid-column:1/-1;text-align:center;color:var(--muted);padding:60px 0}

/* ---------- Section: how it works ---------- */
.cgp-how__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;list-style:none;margin:0;padding:0;counter-reset:step}
.cgp-how__card{
  position:relative;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:38px 32px;overflow:hidden;
  transition:transform .3s var(--ease),border-color .3s;
}
.cgp-how__card:hover{transform:translateY(-5px);border-color:var(--line-strong)}
.cgp-how__num{
  font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--accent);
  display:inline-block;margin-bottom:18px;padding:6px 12px;border:1px solid rgba(251,86,7,.3);border-radius:999px;background:var(--accent-soft);
}
.cgp-how__card h3{font-size:21px}
.cgp-how__card p{color:var(--muted);font-size:15px;margin:0}

/* ---------- Motion ---------- */
.cgp-motion__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cgp-motion__card{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);aspect-ratio:1;display:block}
.cgp-motion__card video,.cgp-motion__card img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.cgp-motion__card:hover video,.cgp-motion__card:hover img{transform:scale(1.03)}
.cgp-motion__play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:66px;height:66px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(10,10,11,.7);border:1px solid var(--line-strong);backdrop-filter:blur(6px);color:#fff;
  transition:opacity .3s,transform .3s var(--ease);
}
.cgp-motion__card:hover .cgp-motion__play{opacity:0;transform:translate(-50%,-50%) scale(.8)}
.cgp-motion__name{
  position:absolute;left:0;right:0;bottom:0;padding:36px 20px 16px;
  font-family:var(--display);font-weight:600;font-size:17px;color:#fff;
  background:linear-gradient(0deg,rgba(10,10,11,.85),transparent);
}

/* ---------- Testimonials ---------- */
.cgp-testis__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cgp-testi{
  margin:0;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:32px;display:flex;flex-direction:column;gap:16px;
  transition:transform .3s var(--ease),border-color .3s;
}
.cgp-testi:hover{transform:translateY(-4px);border-color:var(--line-strong)}
.cgp-testi__stars{display:flex;gap:3px;color:var(--foil)}
.cgp-testi__stars .cgp-ic{width:15px;height:15px}
.cgp-testi blockquote{margin:0;font-size:15.5px;color:var(--text)}
.cgp-testi blockquote p{margin:0}
.cgp-testi figcaption{display:flex;align-items:center;gap:12px;margin-top:auto}
.cgp-testi__avatar{width:42px;height:42px;border-radius:50%;object-fit:cover}
.cgp-testi__name{font-weight:600;font-size:14.5px}
.cgp-testi__role{color:var(--faint);font-size:12.5px}

/* ---------- Portfolio ---------- */
.cgp-folio{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.cgp-folio__item{position:relative;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--line);aspect-ratio:1}
.cgp-folio__item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.cgp-folio__item:hover img{transform:scale(1.05)}
.cgp-folio__name{
  position:absolute;inset:auto 0 0;padding:26px 14px 12px;font-size:13px;font-weight:500;color:#fff;
  background:linear-gradient(0deg,rgba(10,10,11,.85),transparent);
  opacity:0;transition:opacity .3s;
}
.cgp-folio__item:hover .cgp-folio__name{opacity:1}
.cgp-masonry{columns:3;column-gap:18px}
.cgp-masonry__item{break-inside:avoid;margin:0 0 18px;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--line);position:relative}
.cgp-masonry__item.is-hidden{display:none}
.cgp-masonry__item button{padding:0;display:block;width:100%}
.cgp-masonry__item img{width:100%;transition:transform .5s var(--ease)}
.cgp-masonry__item:hover img{transform:scale(1.03)}
.cgp-masonry__item figcaption{position:absolute;inset:auto 0 0;padding:26px 14px 12px;font-size:13px;color:#fff;background:linear-gradient(0deg,rgba(10,10,11,.85),transparent);opacity:0;transition:opacity .3s}
.cgp-masonry__item:hover figcaption{opacity:1}
.cgp-folio-filters{margin-bottom:28px}

/* ---------- FAQ ---------- */
.cgp-faq__list{display:flex;flex-direction:column;gap:12px}
.cgp-faq__item{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;transition:border-color .25s}
.cgp-faq__item[open]{border-color:var(--line-strong)}
.cgp-faq__item summary{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:20px 24px;cursor:pointer;font-family:var(--display);font-weight:600;font-size:16.5px;
  list-style:none;
}
.cgp-faq__item summary::-webkit-details-marker{display:none}
.cgp-faq__chev{width:10px;height:10px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:rotate(45deg);transition:transform .25s var(--ease);flex-shrink:0}
.cgp-faq__item[open] .cgp-faq__chev{transform:rotate(225deg)}
.cgp-faq__body{padding:0 24px 22px;color:var(--muted);font-size:15px}

/* ---------- CTA band ---------- */
.cgp-cta-band{padding:120px 0;background:
  radial-gradient(700px 340px at 50% 0,rgba(251,86,7,.14),transparent),
  var(--ink);
  border-top:1px solid var(--line);
}
.cgp-cta-band__in{text-align:center;max-width:640px;margin:0 auto}
.cgp-cta-band h2{font-size:clamp(30px,4.4vw,48px)}
.cgp-cta-band p{color:var(--muted);font-size:17px}
.cgp-cta-band__actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:30px}

/* ---------- Footer ---------- */
.cgp-footer{border-top:1px solid var(--line);padding:80px 0 34px;background:#08080A}
.cgp-footer__top{display:grid;grid-template-columns:1.3fr 1fr 1.2fr;gap:60px;padding-bottom:60px;border-bottom:1px solid var(--line)}
.cgp-footer__brand p{color:var(--muted);font-size:14.5px;margin:16px 0 12px;max-width:34ch}
.cgp-footer__ig{font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;color:var(--accent)}
.cgp-footer__list,.cgp-footer__legal{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.cgp-footer__list a{color:var(--muted);font-size:14.5px}
.cgp-footer__list a:hover{color:var(--text)}
.cgp-footer__news h3{font-size:19px}
.cgp-footer__news p{color:var(--muted);font-size:14px;margin-bottom:16px}
.cgp-footer__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;padding-top:30px;color:var(--faint);font-size:12.5px}
.cgp-footer__legal{flex-direction:row;gap:22px}
.cgp-footer__legal a{color:var(--faint);font-size:12.5px}
.cgp-footer__legal a:hover{color:var(--muted)}

/* ---------- Floating CTA ---------- */
.cgp-float-cta{
  position:fixed;right:26px;bottom:26px;z-index:80;
  display:inline-flex;align-items:center;gap:10px;
  background:linear-gradient(135deg,var(--accent),#E14A00);color:#fff;
  font-family:var(--display);font-weight:600;font-size:14.5px;
  padding:14px 24px;border-radius:999px;box-shadow:0 10px 34px rgba(251,86,7,.45);
  opacity:0;transform:translateY(18px);pointer-events:none;
  transition:opacity .35s,transform .35s var(--ease);
}
.cgp-float-cta.is-visible{opacity:1;transform:none;pointer-events:auto}
.cgp-float-cta:hover{color:#fff;transform:translateY(-3px)}

/* ---------- Toasts & confetti ---------- */
.cgp-toasts{position:fixed;left:50%;bottom:30px;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:10px;align-items:center;pointer-events:none}
.cgp-toast{
  background:var(--panel);border:1px solid var(--line-strong);border-radius:999px;
  padding:12px 24px;font-size:14px;font-weight:500;box-shadow:var(--shadow-2);
  display:flex;align-items:center;gap:10px;
  animation:toastIn .35s var(--ease);
}
.cgp-toast--ok{border-color:rgba(53,208,127,.45)}
.cgp-toast--ok .cgp-ic{color:var(--success)}
.cgp-toast--err{border-color:rgba(229,72,77,.45)}
@keyframes toastIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.cgp-confetti{position:fixed;top:-12px;z-index:210;width:9px;height:15px;pointer-events:none;animation:confetti 2.6s ease-in forwards}
@keyframes confetti{to{transform:translateY(105vh) rotate(720deg);opacity:.2}}

/* ---------- Breadcrumbs ---------- */
.cgp-crumbs{padding:26px 0 0}
.cgp-crumbs ol{display:flex;flex-wrap:wrap;gap:8px;list-style:none;margin:0;padding:0;font-family:var(--mono);font-size:11.5px;letter-spacing:.06em}
.cgp-crumbs li:not(:last-child)::after{content:"/";margin-left:8px;color:var(--faint)}
.cgp-crumbs a{color:var(--muted)}
.cgp-crumbs span{color:var(--faint)}

/* ---------- Product page ---------- */
.cgp-product{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:56px;padding-top:30px;padding-bottom:110px;align-items:start}
.cgp-gallery__main{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);background:var(--panel)}
.cgp-gallery__zoom{padding:0;display:block;width:100%;cursor:zoom-in}
.cgp-gallery__main img,.cgp-gallery__main video{width:100%;aspect-ratio:1;object-fit:cover}
.cgp-gallery__thumbs{display:flex;gap:12px;margin-top:14px;overflow-x:auto;padding-bottom:4px}
.cgp-gallery__thumbs button{padding:0;border-radius:var(--r-sm);overflow:hidden;border:2px solid transparent;flex-shrink:0;transition:border-color .2s}
.cgp-gallery__thumbs button.is-active,.cgp-gallery__thumbs button:hover{border-color:var(--accent)}
.cgp-gallery__thumbs img{width:76px;height:76px;object-fit:cover}
.cgp-product__desc{margin-top:44px;color:var(--muted);font-size:15.5px}
.cgp-product__desc h2,.cgp-product__desc h3{color:var(--text)}
.cgp-product__panel{position:sticky;top:104px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:36px;box-shadow:var(--shadow-1)}
.cgp-product__title{font-size:clamp(26px,3vw,36px)}
.cgp-product__short{color:var(--muted);font-size:15px;margin-bottom:22px}
.cgp-product__archived-box{border:1px solid rgba(229,72,77,.35);background:rgba(229,72,77,.06);border-radius:var(--r-md);padding:24px}
.cgp-product__archived-box p{color:var(--muted)}

/* Configurator */
.cgp-hp{position:absolute;left:-9999px;opacity:0;height:0;width:0}
.cgp-config__steps{display:flex;gap:4px;list-style:none;margin:0 0 26px;padding:0}
.cgp-config__steps li{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;
  font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);
  position:relative;padding-top:2px;
}
.cgp-config__steps li span{
  width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line-strong);font-size:11px;transition:all .3s var(--ease);
}
.cgp-config__steps li.is-current{color:var(--text)}
.cgp-config__steps li.is-current span{background:var(--accent);border-color:var(--accent);color:#fff}
.cgp-config__steps li.is-done span{border-color:var(--success);color:var(--success)}
.cgp-step{display:none;border:0;padding:0;margin:0;animation:stepIn .35s var(--ease)}
.cgp-step.is-active{display:block}
@keyframes stepIn{from{opacity:0;transform:translateX(14px)}to{opacity:1;transform:none}}
.cgp-step__legend{font-family:var(--display);font-weight:600;font-size:17px;margin-bottom:16px;padding:0}
.cgp-step__hint{font-size:13px;color:var(--faint)}
.cgp-field{margin-bottom:14px;position:relative}
.cgp-field label{display:block;font-size:13px;font-weight:500;color:var(--muted);margin-bottom:7px}
.cgp-field label em{color:var(--accent);font-style:normal}
.cgp-field input,.cgp-field textarea{
  width:100%;background:var(--panel-2);border:1px solid var(--line-strong);border-radius:var(--r-sm);
  color:var(--text);font:inherit;font-size:14.5px;padding:12px 14px;outline:none;
  transition:border-color .2s;
}
.cgp-field input:focus,.cgp-field textarea:focus{border-color:var(--accent)}
.cgp-field input.is-invalid,.cgp-field textarea.is-invalid{border-color:var(--archived)}
.cgp-field__count{position:absolute;right:8px;bottom:6px;font-family:var(--mono);font-size:10px;color:var(--faint)}
.cgp-addons{display:flex;flex-direction:column;gap:9px;max-height:340px;overflow-y:auto;padding-right:6px}
.cgp-addon{
  display:flex;align-items:center;gap:13px;padding:13px 15px;
  background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-sm);
  cursor:pointer;transition:border-color .2s,background .2s;
}
.cgp-addon:hover{border-color:var(--line-strong)}
.cgp-addon input{position:absolute;opacity:0;pointer-events:none}
.cgp-addon__box{
  width:21px;height:21px;border-radius:6px;border:1.5px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;color:transparent;flex-shrink:0;
  transition:all .2s var(--ease);
}
.cgp-addon input:checked ~ .cgp-addon__box{background:var(--accent);border-color:var(--accent);color:#fff}
.cgp-addon input:checked ~ .cgp-addon__label{color:var(--text)}
.cgp-addon input:focus-visible ~ .cgp-addon__box{outline:2px solid var(--accent);outline-offset:2px}
.cgp-addon:has(input:checked){border-color:rgba(251,86,7,.5);background:var(--accent-soft)}
.cgp-addon__label{flex:1;font-size:14px;font-weight:500;color:var(--muted);display:flex;flex-direction:column}
.cgp-addon__label small{font-weight:400;font-size:12px;color:var(--faint)}
.cgp-addon__price{font-family:var(--mono);font-size:13px;color:var(--text);white-space:nowrap}
.cgp-summary{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-md);padding:20px}
.cgp-summary__row{display:flex;justify-content:space-between;gap:16px;font-size:14.5px;padding:7px 0}
.cgp-summary__row--total{border-top:1px solid var(--line-strong);margin-top:8px;padding-top:14px;font-family:var(--display);font-weight:600;font-size:17px}
.cgp-summary__addons .cgp-summary__row{color:var(--muted);font-size:13.5px}
.cgp-summary__note{font-size:12px;color:var(--faint);margin:12px 0 0}
.cgp-config__nav{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
.cgp-config__nav .cgp-btn{flex:1 1 auto;min-width:0}
.cgp-config__nav .cgp-btn--lg{padding:15px 28px;font-size:15px}
.cgp-config__nav [hidden]{display:none !important}
#cgp-step-back{flex:0 0 auto}

/* Upload drop */
.cgp-upload-drop{
  display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;
  border:1.5px dashed var(--line-strong);border-radius:var(--r-md);
  padding:34px 20px;cursor:pointer;color:var(--muted);
  transition:border-color .25s,background .25s;
}
.cgp-upload-drop:hover,.cgp-upload-drop.is-drag{border-color:var(--accent);background:var(--accent-soft);color:var(--text)}
.cgp-upload-drop .cgp-ic{width:26px;height:26px;color:var(--accent)}
.cgp-upload-drop small{color:var(--faint);font-size:12px}
.cgp-upload-list,.cgp-portal-upload__list{list-style:none;margin:14px 0 0;padding:0;display:flex;flex-direction:column;gap:8px}
.cgp-upload-list li,.cgp-portal-upload__list li{
  display:flex;align-items:center;gap:10px;font-size:13px;
  background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:9px 12px;
}
.cgp-upload-list li .bar{flex:1;height:4px;border-radius:4px;background:var(--line);overflow:hidden}
.cgp-upload-list li .bar span{display:block;height:100%;background:var(--accent);width:0;transition:width .3s}
.cgp-upload-list li.is-done .bar span{background:var(--success)}
.cgp-upload-list li.is-err{border-color:rgba(229,72,77,.4)}
.cgp-upload-list li button{color:var(--faint)}
.cgp-upload-list li button:hover{color:var(--archived)}

/* Trust + license */
.cgp-trust{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:26px}
.cgp-trust span{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--muted)}
.cgp-trust .cgp-ic{width:16px;height:16px;color:var(--accent);flex-shrink:0}
.cgp-license{margin:18px 0 0;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--foil)}

/* Sticky mobile CTA */
.cgp-mobile-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:85;
  display:none;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 20px calc(14px + env(safe-area-inset-bottom));
  background:rgba(10,10,11,.92);backdrop-filter:blur(14px);border-top:1px solid var(--line-strong);
}
.cgp-mobile-cta__price{font-family:var(--mono);font-size:17px;font-weight:600}

/* Lightbox */
.cgp-lightbox{position:fixed;inset:0;z-index:180;background:rgba(4,4,5,.92);align-items:center;justify-content:center;padding:40px;display:none}
.cgp-lightbox.is-open{display:flex}
.cgp-lightbox[hidden]{display:none !important}
.cgp-lightbox img{max-width:min(92vw,900px);max-height:88vh;width:auto;border-radius:var(--r-md);box-shadow:var(--shadow-2)}
.cgp-lightbox__close{position:absolute;top:20px;right:20px;width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;background:rgba(255,255,255,.08)}

/* ---------- Quick view ---------- */
.cgp-qv{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
.cgp-qv__media{border-radius:var(--r-md);overflow:hidden;border:1px solid var(--line)}
.cgp-qv__media img{width:100%;aspect-ratio:1;object-fit:cover}
.cgp-qv__title{font-size:24px;margin:12px 0 6px}
.cgp-qv__price{font-family:var(--mono);font-size:19px;margin-bottom:14px}
.cgp-qv__desc{color:var(--muted);font-size:14.5px;margin-bottom:20px}
.cgp-qv__archived{color:var(--archived);font-size:14px}
.cgp-qv__note{margin-top:16px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--foil)}

/* ---------- Timeline (project tracker) ---------- */
.cgp-timeline{margin:22px 0}
.cgp-timeline__meter{height:7px;border-radius:999px;background:var(--panel-2);border:1px solid var(--line);overflow:hidden}
.cgp-timeline__bar{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .8s var(--ease)}
.cgp-timeline__meta{display:flex;justify-content:space-between;margin:10px 0 22px;font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;color:var(--muted)}
.cgp-timeline__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.cgp-timeline__list li{
  position:relative;display:grid;grid-template-columns:auto 1fr auto;grid-template-areas:"dot label date" ". desc desc";
  column-gap:16px;padding:0 0 22px 0;
}
.cgp-timeline__list li::before{
  content:"";position:absolute;left:7px;top:20px;bottom:0;width:2px;background:var(--line);
}
.cgp-timeline__list li:last-child::before{display:none}
.cgp-timeline__dot{grid-area:dot;width:16px;height:16px;border-radius:50%;border:2px solid var(--line-strong);background:var(--ink);margin-top:3px}
.cgp-timeline__list li.is-done .cgp-timeline__dot{background:var(--success);border-color:var(--success)}
.cgp-timeline__list li.is-current .cgp-timeline__dot{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 5px var(--accent-soft)}
.cgp-timeline__label{grid-area:label;font-weight:600;font-size:15px}
.cgp-timeline__list li.is-todo .cgp-timeline__label{color:var(--faint)}
.cgp-timeline__desc{grid-area:desc;font-size:13px;color:var(--muted);margin-left:32px}
.cgp-timeline__list li.is-todo .cgp-timeline__desc{color:var(--faint)}
.cgp-timeline__date{grid-area:date;font-family:var(--mono);font-size:11px;color:var(--faint)}

/* ---------- Portal ---------- */
.cgp-portal-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0}
.cgp-portal-card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);
  padding:22px;display:flex;flex-direction:column;gap:9px;transition:border-color .25s,transform .25s var(--ease);
}
.cgp-portal-card:hover{border-color:var(--accent);transform:translateY(-3px)}
.cgp-portal-card__no{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--faint)}
.cgp-portal-card__stage{font-family:var(--display);font-weight:600;font-size:17px}
.cgp-portal-card__meter{height:5px;border-radius:999px;background:var(--panel-2);overflow:hidden}
.cgp-portal-card__meter span{display:block;height:100%;background:var(--accent);border-radius:999px}
.cgp-portal-card__pct{font-family:var(--mono);font-size:11px;color:var(--muted)}
.cgp-project{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:34px;margin-bottom:26px}
.cgp-project__head{display:flex;justify-content:space-between;align-items:baseline;gap:16px;flex-wrap:wrap}
.cgp-project__head h3{margin:0}
.cgp-project__date{font-family:var(--mono);font-size:12px;color:var(--faint)}
.cgp-project__items{list-style:none;margin:8px 0 0;padding:0;color:var(--muted);font-size:14px}
.cgp-project__downloads{margin-top:22px;padding:18px;border:1px solid rgba(53,208,127,.3);border-radius:var(--r-md);background:rgba(53,208,127,.05)}
.cgp-project__downloads h4{margin:0 0 10px;font-size:15px}
.cgp-project__downloads ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px}
.cgp-project__downloads a{color:var(--success);font-size:14px}
.cgp-project__actions{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:26px}
.cgp-portal-revision label{display:block;font-size:13px;font-weight:500;color:var(--muted);margin-bottom:8px}
.cgp-portal-revision textarea{
  width:100%;background:var(--panel-2);border:1px solid var(--line-strong);border-radius:var(--r-sm);
  color:var(--text);font:inherit;font-size:14px;padding:12px;outline:none;margin-bottom:12px;
}
.cgp-portal-revision textarea:focus{border-color:var(--accent)}
.cgp-portal-revision__done{color:var(--success);font-size:13.5px}
.cgp-empty{text-align:center;padding:70px 20px}
.cgp-empty h2,.cgp-empty h3{font-size:26px}
.cgp-empty p{color:var(--muted)}

/* ---------- Blog / pages / archive ---------- */
.cgp-archive,.cgp-page{padding-top:20px;padding-bottom:120px}
.cgp-posts{display:flex;flex-direction:column;gap:26px}
.cgp-post-card{display:grid;grid-template-columns:280px 1fr;gap:28px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:border-color .25s,transform .25s var(--ease)}
.cgp-post-card:hover{border-color:var(--line-strong);transform:translateY(-3px)}
.cgp-post-card__media img{width:100%;height:100%;object-fit:cover}
.cgp-post-card__body{padding:28px 30px 28px 0}
.cgp-post-card__date{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.cgp-post-card h2{font-size:22px;margin:8px 0 10px}
.cgp-post-card p{color:var(--muted);font-size:14.5px;margin:0}
.cgp-entry__hero{margin:0 0 40px;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line)}
.cgp-entry__content{color:#CFCDC6;font-size:16.5px}
.cgp-entry__content h2{font-size:28px;margin-top:1.6em}
.cgp-entry__content h3{font-size:22px;margin-top:1.4em}
.cgp-entry__content a{color:var(--accent-2);text-decoration:underline;text-underline-offset:3px}
.cgp-entry__content img{border-radius:var(--r-md)}
.cgp-entry__content blockquote{margin:1.6em 0;padding:4px 0 4px 24px;border-left:3px solid var(--accent);color:var(--muted);font-style:italic}
.cgp-pagination{margin-top:50px;text-align:center}
.cgp-pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 10px;border-radius:999px;border:1px solid var(--line-strong);color:var(--muted);margin:0 3px;font-family:var(--mono);font-size:13px}
.cgp-pagination .page-numbers.current{background:var(--accent);border-color:var(--accent);color:#fff}
.cgp-pagination a.page-numbers:hover{border-color:var(--accent);color:var(--text)}
.cgp-404{padding:140px 28px;text-align:center}
.cgp-404 h1{font-size:clamp(32px,5vw,54px);margin-top:26px}
.cgp-404 p{color:var(--muted)}
.cgp-404 .cgp-btn{margin-top:16px}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease);transition-delay:var(--d,0ms)}
.reveal.is-in{opacity:1;transform:none}
html.no-js .reveal,body.wp-admin .reveal{opacity:1;transform:none}

/* ==========================================================================
   WooCommerce — scoped styling for cart / checkout / account.
   Payment containers (#payment, .wc_payment_methods, PayPal SDK nodes)
   are intentionally untouched: nothing here sets display/visibility on them.
   ========================================================================== */
.woocommerce-page .cgp-main{max-width:var(--wrap);margin:0 auto;padding:30px 28px 120px}
body.woocommerce-cart .cgp-main,
body.woocommerce-checkout .cgp-main,
body.woocommerce-account .cgp-main{min-height:52vh}

.woocommerce table.shop_table{
  width:100%;border-collapse:collapse;border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;
}
.woocommerce table.shop_table th,
.woocommerce table.shop_table td{padding:16px;border-bottom:1px solid var(--line);text-align:left;font-size:14.5px}
.woocommerce table.shop_table th{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);background:var(--panel)}
.woocommerce table.shop_table img{width:64px;border-radius:8px}
.woocommerce .cart_item .product-name a{font-weight:600}
.woocommerce .quantity .qty{
  width:70px;background:var(--panel-2);border:1px solid var(--line-strong);border-radius:var(--r-sm);
  color:var(--text);padding:9px;text-align:center;font:inherit;
}
.woocommerce .coupon .input-text{
  background:var(--panel-2);border:1px solid var(--line-strong);border-radius:999px;
  color:var(--text);padding:11px 18px;font:inherit;font-size:14px;
}
.woocommerce button.button,
.woocommerce a.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce button[name="update_cart"],
.woocommerce .checkout-button,
.woocommerce #place_order{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--display);font-weight:600;font-size:15px;
  background:linear-gradient(135deg,var(--accent),#E14A00);color:#fff;
  border:0;border-radius:999px;padding:13px 26px;cursor:pointer;
  transition:transform .25s var(--ease),box-shadow .25s;
}
.woocommerce button.button:hover,
.woocommerce a.button:hover,
.woocommerce #place_order:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(251,86,7,.45);color:#fff}
.woocommerce button.button[disabled]{opacity:.5;transform:none}
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-checkout #order_review{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select{
  width:100%;background:var(--panel-2);border:1px solid var(--line-strong);border-radius:var(--r-sm);
  color:var(--text);font:inherit;font-size:14.5px;padding:12px 14px;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus{border-color:var(--accent);outline:none}
.woocommerce form .form-row label{font-size:13px;font-weight:500;color:var(--muted)}
.woocommerce .select2-container--default .select2-selection--single{
  background:var(--panel-2);border:1px solid var(--line-strong);border-radius:var(--r-sm);height:auto;padding:8px 6px;
}
.woocommerce .select2-container--default .select2-selection--single .select2-selection__rendered{color:var(--text)}
.select2-dropdown{background:var(--panel-2);border:1px solid var(--line-strong);color:var(--text)}
.select2-container--default .select2-results__option--highlighted[aria-selected]{background:var(--accent)}
.select2-search--dropdown .select2-search__field{background:var(--ink);border:1px solid var(--line-strong);color:var(--text)}
.woocommerce-message,.woocommerce-info,.woocommerce-error{
  list-style:none;background:var(--panel);border:1px solid var(--line-strong);
  border-left:3px solid var(--accent);border-radius:var(--r-sm);
  padding:16px 20px;margin:0 0 24px;color:var(--text);font-size:14.5px;
}
.woocommerce-error{border-left-color:var(--archived)}
.woocommerce-message a.button,.woocommerce-info a.button{margin-left:12px;padding:8px 16px;font-size:13px}
.cgp-checkout-trust{
  display:flex;flex-wrap:wrap;gap:16px;margin:18px 0;padding:16px;
  border:1px solid var(--line);border-radius:var(--r-md);background:var(--panel-2);
}
.cgp-checkout-trust span{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted)}
.cgp-checkout-trust .cgp-ic{width:15px;height:15px;color:var(--accent)}
/* Payment box: readable dark styling ONLY — no display/visibility rules. */
.woocommerce-checkout #payment{background:var(--panel-2);border-radius:var(--r-md)}
.woocommerce-checkout #payment .payment_box{background:rgba(255,255,255,.04);color:var(--muted);border-radius:var(--r-sm)}
.woocommerce-checkout #payment ul.payment_methods{border-bottom:1px solid var(--line);padding:18px}
.woocommerce-checkout #payment ul.payment_methods li label{color:var(--text)}

/* Account */
.woocommerce-account .woocommerce-MyAccount-navigation{float:none;width:100%;margin-bottom:30px}
.woocommerce-account .woocommerce-MyAccount-navigation ul{display:flex;flex-wrap:wrap;gap:8px;list-style:none;margin:0;padding:0}
.woocommerce-account .woocommerce-MyAccount-navigation li a{
  display:block;padding:10px 20px;border-radius:999px;border:1px solid var(--line-strong);
  font-size:13.5px;font-weight:500;color:var(--muted);
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.woocommerce-account .woocommerce-MyAccount-content{float:none;width:100%}

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .cgp-grid,.cgp-shop-skeletons{grid-template-columns:repeat(3,1fr)}
  .cgp-folio{grid-template-columns:repeat(3,1fr)}
  .cgp-hero__in{grid-template-columns:1fr;gap:44px}
  .cgp-hero__wall{height:380px}
  .cgp-product{grid-template-columns:1fr;gap:40px}
  .cgp-product__panel{position:static}
  .cgp-footer__top{grid-template-columns:1fr 1fr}
  .cgp-masonry{columns:2}
}
@media (max-width:820px){
  .cgp-sec{padding:80px 0}
  .cgp-nav{display:none}
  .cgp-header__cta{display:none}
  .cgp-burger{display:inline-flex}
  .cgp-grid,.cgp-shop-skeletons{grid-template-columns:repeat(2,1fr);gap:14px}
  .cgp-stats__grid{grid-template-columns:repeat(2,1fr)}
  .cgp-how__grid,.cgp-motion__grid,.cgp-testis__grid{grid-template-columns:1fr}
  .cgp-portal-cards{grid-template-columns:1fr}
  .cgp-project__actions{grid-template-columns:1fr}
  .cgp-post-card{grid-template-columns:1fr}
  .cgp-post-card__body{padding:24px}
  .cgp-qv{grid-template-columns:1fr}
  .cgp-shop-bar{position:static}
  .cgp-mobile-cta{display:flex}
  .cgp-float-cta{display:none}
  .cgp-footer__top{grid-template-columns:1fr;gap:40px}
  .cgp-trust{grid-template-columns:1fr}
  .cgp-hero{padding:70px 0 60px}
  .cgp-wrap{padding:0 20px}
  .cgp-header__in{padding:0 20px}
  .cgp-overlay{padding:6vh 14px 30px}
  .cgp-overlay__panel{padding:28px 22px}
}
@media (max-width:480px){
  .cgp-grid,.cgp-shop-skeletons{grid-template-columns:1fr}
  .cgp-folio{grid-template-columns:repeat(2,1fr)}
  .cgp-masonry{columns:1}
  .cgp-hero__actions .cgp-btn{width:100%}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  html{scroll-behavior:auto}
  .cgp-wall__track,.cgp-logos__track{animation:none}
  .reveal{opacity:1;transform:none}
}

/* ---------- Print ---------- */
@media print{
  .cgp-header,.cgp-footer,.cgp-float-cta,.cgp-mobile-cta,.cgp-announce,.cgp-cta-band{display:none}
  body{background:#fff;color:#000}
}
