/* ============================================================
   PICKY — cinematic underwater portfolio
   Refined dark theme · frosted glass · animated caustics
   ============================================================ */
@font-face{
  font-family:"Riffic";
  src:url("assets/fonts/Riffic.woff") format("woff"),
      url("assets/fonts/Riffic.ttf") format("truetype");
  font-weight:400 700; font-style:normal; font-display:swap;
}

:root{
  --bg:        #051320;
  --bg-2:      #071a2b;
  --text:      #e9f4fb;
  --muted:     #93b0c4;
  --faint:     #5d7b90;
  --accent:    #54d3ff;
  --accent-2:  #2aa6e6;
  --gold:      #ffc23d;   /* echoes the sunglasses in the logo */
  --gold-2:    #ff9a1f;
  --line:      rgba(255,255,255,.09);
  --line-2:    rgba(255,255,255,.16);
  /* opaque-ish panels (no live backdrop-blur — keeps scrolling smooth) */
  --glass:     rgba(9, 26, 42, 0.82);
  --glass-2:   rgba(12, 34, 53, 0.88);
  --shadow:    0 30px 60px -30px rgba(0,0,0,.8);
  --r:         16px;
  --maxw:      1180px;
  --disp:      "Space Grotesk", system-ui, sans-serif;
  --body:      "Inter", system-ui, sans-serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--body); color:var(--text); background:var(--bg);
  line-height:1.65; overflow-x:hidden; -webkit-font-smoothing:antialiased;
  letter-spacing:-0.01em;
}
h1,h2,h3{ font-family:var(--disp); font-weight:600; letter-spacing:-0.03em; line-height:1.04; }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
strong{ color:var(--text); font-weight:600; }
.accent{ color:var(--accent); }
.gold{ color:var(--gold); }

/* ===== CINEMATIC BACKGROUND ===== */
.bg{ position:fixed; inset:0; z-index:-2; overflow:hidden; background:var(--bg); }
/* the real underwater scene — blurred + darkened so it reads as depth,
   not a busy illustration, with a slow cinematic drift */
.bg__img{
  position:absolute; inset:-6%;
  background-color:#0a3454;
  background-repeat:no-repeat; background-position:center center; background-size:cover;
  background-image:
    url("assets/background.png"),
    radial-gradient(120% 90% at 50% 0%, #1f6f9e 0%, #0d3f60 42%, #07273f 72%, #04141f 100%);
  filter:blur(7px) brightness(.6) saturate(1.2);   /* fallback only; JS bakes a static blurred image and clears this */
  transform:scale(1.1);
}
/* colour grade for contrast + a touch of brand teal */
.bg__grade{
  position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(120% 85% at 50% 8%, rgba(84,211,255,.10), transparent 55%),
    linear-gradient(180deg, rgba(4,18,30,.34) 0%, rgba(4,16,26,.22) 42%, rgba(3,12,20,.7) 100%);
}
.bg__vignette{
  position:absolute; inset:0; pointer-events:none;
  box-shadow:inset 0 0 240px 70px rgba(2,10,18,.9);
  background:radial-gradient(120% 100% at 50% 45%, transparent 50%, rgba(2,10,18,.6) 100%);
}

/* ===== NAV ===== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; gap:22px;
  padding:18px clamp(16px,4vw,44px);
  transition:padding .3s ease, background .3s ease, border-color .3s ease;
  border-bottom:1px solid transparent;
}
.nav.shrink{
  padding-top:11px; padding-bottom:11px;
  background:rgba(5,17,28,.94);
  border-bottom-color:var(--line);
}
.nav__brand{ display:flex; align-items:center; gap:11px; font-family:var(--disp);
  font-size:1.18rem; font-weight:600; letter-spacing:-0.02em; }
.nav__wordmark{ height:44px; width:auto; transition:transform .25s ease;
  filter:drop-shadow(0 4px 7px rgba(0,0,0,.45)); }
.nav__brand:hover .nav__wordmark{ transform:rotate(-3deg) scale(1.05); }
.nav__links{ display:flex; gap:4px; margin-left:auto; }
.nav__links a{
  padding:8px 15px; border-radius:9px; font-size:.92rem; font-weight:500; color:var(--muted);
  transition:.2s;
}
.nav__links a:hover{ color:var(--text); background:rgba(255,255,255,.05); }

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex; align-items:center; gap:9px;
  padding:12px 22px; border-radius:11px; font-family:var(--body); font-weight:600; font-size:.95rem;
  cursor:pointer; border:1px solid transparent; transition:.22s ease; white-space:nowrap;
}
.btn .i{ width:18px; height:18px; }
.btn--solid{
  color:#03161f; background:linear-gradient(180deg, #7fe1ff, var(--accent) 55%, var(--accent-2));
  box-shadow:0 12px 26px -12px rgba(84,211,255,.7);
}
.btn--solid:hover{ transform:translateY(-2px); box-shadow:0 18px 34px -14px rgba(84,211,255,.8); }
.btn--ghost{ color:var(--text); background:rgba(255,255,255,.04); border-color:var(--line-2); }
.btn--ghost:hover{ background:rgba(255,255,255,.09); border-color:var(--accent); transform:translateY(-2px); }
.nav__burger{ display:none; background:none; border:0; cursor:pointer; flex-direction:column; gap:5px; padding:8px; }
.nav__burger span{ width:24px; height:2px; border-radius:2px; background:var(--text); transition:.25s; }

/* ===== LAYOUT ===== */
.section{ max-width:var(--maxw); margin:0 auto; padding:clamp(70px,11vw,120px) clamp(16px,4vw,28px); }
.section--tight{ padding-top:40px; padding-bottom:40px; }
.section__head{ max-width:680px; margin:0 auto 54px; text-align:center; }
.eyebrow{
  display:inline-block; font-family:var(--body); font-weight:600; font-size:.78rem;
  letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin-bottom:16px;
}
.section__head h2{ font-size:clamp(2rem,4.4vw,3rem); }
.section__head p{ color:var(--muted); margin-top:14px; font-size:1.02rem; }

/* ===== HERO ===== */
.hero{ min-height:100vh; display:flex; flex-direction:column; justify-content:center;
  max-width:var(--maxw); margin:0 auto; padding:120px clamp(16px,4vw,28px) 80px; position:relative; }
.hero__inner{ display:grid; grid-template-columns:1.1fr .9fr; gap:56px; align-items:center; }
.status{
  display:inline-flex; align-items:center; gap:9px; padding:7px 15px; border-radius:999px;
  font-size:.82rem; font-weight:500; color:var(--muted);
  background:rgba(255,255,255,.04); border:1px solid var(--line); margin-bottom:26px;
}
.status i{ width:8px; height:8px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 0 0 rgba(84,211,255,.7); animation:ping 2.2s ease-out infinite; }
@keyframes ping{ 0%{ box-shadow:0 0 0 0 rgba(84,211,255,.6);} 70%,100%{ box-shadow:0 0 0 10px rgba(84,211,255,0);} }
.hero__heading{ font-size:clamp(2.2rem,5.2vw,3.6rem); font-weight:600; margin-bottom:20px; }
.hero__sub{ color:var(--muted); font-size:1.1rem; max-width:480px; margin-bottom:34px; }

/* the logo is now the hero centerpiece (right column) */
.hero__inner{ grid-template-columns:1fr 1fr; }
.hero__logo-art{ width:min(100%,520px); height:auto;
  filter:drop-shadow(0 18px 30px rgba(0,0,0,.5)) drop-shadow(0 0 44px rgba(84,211,255,.22));
  animation:logoin .9s cubic-bezier(.2,.7,.2,1) both, logobob 6s ease-in-out 1s infinite; }
@keyframes logoin{ from{ opacity:0; transform:translateY(20px) rotate(-3deg) scale(.95);} to{ opacity:1; transform:none;} }
@keyframes logobob{ 0%,100%{ transform:translateY(0) rotate(0);} 50%{ transform:translateY(-12px) rotate(-1.2deg);} }
/* styled text fallback until logo.png is added */
.hero__logo-fallback{ display:grid; place-items:center; font-family:var(--disp); font-weight:700;
  font-size:clamp(3.4rem,9vw,5.6rem); letter-spacing:-0.03em;
  background:linear-gradient(180deg,#bdeeff,var(--accent) 55%,var(--accent-2));
  -webkit-background-clip:text; background-clip:text; color:transparent;
  filter:drop-shadow(0 6px 16px rgba(0,0,0,.4)); }
.hero__btns{ display:flex; gap:13px; flex-wrap:wrap; margin-bottom:46px; }
.stats{ display:flex; gap:42px; flex-wrap:wrap; }
.stat b{ display:block; font-family:var(--disp); font-weight:700; font-size:2.2rem; line-height:1; letter-spacing:-0.03em;
  background:linear-gradient(180deg, #ffe1a0, var(--gold) 60%, var(--gold-2));
  -webkit-background-clip:text; background-clip:text; color:transparent; }
.stat span{ font-size:.82rem; color:var(--muted); font-weight:600; }

.hero__art{ position:relative; display:flex; justify-content:center;
  transition:transform .4s cubic-bezier(.2,.7,.2,1); will-change:transform; }

/* bubbles drifting up across the whole site (lives in the fixed .bg layer) */
.bg__bubbles{ position:absolute; inset:0; overflow:hidden; pointer-events:none; }
.hero__inner{ position:relative; z-index:1; }
.bubble{
  position:absolute; bottom:-30px; border-radius:50%;
  background:radial-gradient(circle at 32% 30%, rgba(255,255,255,.85), rgba(180,235,255,.18) 55%, transparent 72%);
  border:1px solid rgba(190,238,255,.35);
  animation:rise linear infinite; will-change:transform, opacity;
}
@keyframes rise{
  0%  { transform:translateY(0) translateX(0) scale(.7); opacity:0; }
  12% { opacity:1; }
  55% { transform:translateY(-42vh) translateX(16px) scale(1); }
  100%{ transform:translateY(-96vh) translateX(-10px) scale(1.05); opacity:0; }
}
/* the character art is trimmed of its empty sides at runtime (cropAvatar in JS),
   so we can show the WHOLE character — never cropped — at any screen size */
.hero__avatar{ width:min(100%,440px); height:auto; max-width:100%;
  filter:drop-shadow(0 30px 40px rgba(0,0,0,.55));
  animation:float 6s ease-in-out infinite; }
.hero__halo{
  position:absolute; inset:6% 0 0 0; margin:auto; width:74%; aspect-ratio:1;
  background:radial-gradient(circle, rgba(84,211,255,.40), transparent 64%);
  filter:blur(20px); animation:pulse 6s ease-in-out infinite;
}
@keyframes float{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(-14px);} }
@keyframes pulse{ 0%,100%{ opacity:.5; transform:scale(.95);} 50%{ opacity:.85; transform:scale(1.06);} }

.scroll-hint{ position:absolute; bottom:26px; left:50%; transform:translateX(-50%);
  width:24px; height:38px; border:1.5px solid var(--line-2); border-radius:14px; display:flex; justify-content:center; padding-top:7px; }
.scroll-hint span{ width:3px; height:8px; border-radius:3px; background:var(--accent); animation:scrolldot 1.8s ease-in-out infinite; }
@keyframes scrolldot{ 0%{ opacity:0; transform:translateY(-4px);} 40%{ opacity:1;} 80%,100%{ opacity:0; transform:translateY(10px);} }

/* ===== TABS + GRID ===== */
.tabs{ display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin-bottom:42px; }
.tab{
  padding:9px 20px; border-radius:999px; font-family:var(--body); font-weight:500; font-size:.92rem;
  cursor:pointer; color:var(--muted); background:rgba(255,255,255,.03);
  border:1px solid var(--line); transition:.2s;
}
.tab:hover{ color:var(--text); border-color:var(--line-2); }
.tab.is-active{ color:#03161f; background:linear-gradient(180deg,#7fe1ff,var(--accent) 60%,var(--accent-2)); border-color:transparent; }

.tab-panel{ display:none; }
.tab-panel.is-active{ display:grid; animation:fadein .45s ease; }
@keyframes fadein{ from{ opacity:0; transform:translateY(12px);} to{ opacity:1; transform:none;} }

.grid{ gap:18px; }
.empty{ grid-column:1/-1; text-align:center; color:var(--muted); padding:48px 0; font-weight:500; }
/* group headings inside a grid (logos tab) */
.grid__group{
  grid-column:1/-1; display:flex; align-items:center; gap:14px;
  font-size:1.05rem; font-weight:600; color:var(--accent);
  margin:14px 0 2px; letter-spacing:-0.01em;
}
.grid__group:first-child{ margin-top:0; }
.grid__group::after{ content:""; flex:1; height:1px; background:var(--line); }
.grid--wide{ grid-template-columns:repeat(3,1fr); }
.grid--square{ grid-template-columns:repeat(4,1fr); }
.grid--banner{ grid-template-columns:repeat(2,1fr); }
/* banners: show the WHOLE image at its natural ratio — never crop channel art */
[data-panel="banners"] .card__media{ aspect-ratio:auto; min-height:90px; }
[data-panel="banners"] .card__media img{ height:auto; }
/* wide logos (e.g. 16:9 main logos) span two cells so they fill like the rest;
   2.07:1 ≈ two square cells + the gap, so rows stay perfectly even */
.card--wide{ grid-column:span 2; }
.grid .card--wide .card__media{ aspect-ratio:2.07/1; }

.card{
  position:relative; border-radius:var(--r); overflow:hidden;
  background:var(--glass); border:1px solid var(--line); box-shadow:var(--shadow);
  transition:transform .18s ease, border-color .25s ease, box-shadow .25s ease;
  transform-style:preserve-3d;
}
.card:hover{ border-color:var(--accent);
  box-shadow:0 36px 60px -26px rgba(0,0,0,.85), 0 0 0 1px rgba(84,211,255,.35), 0 22px 50px -24px rgba(84,211,255,.35); }
/* colourful category tag */
.card__tag{
  position:absolute; top:10px; left:10px; z-index:2;
  padding:5px 11px; border-radius:999px; font-size:.72rem; font-weight:700; letter-spacing:.02em;
  color:#3a2400; background:linear-gradient(180deg, #ffd874, var(--gold) 60%, var(--gold-2));
  box-shadow:0 6px 14px -6px rgba(255,154,31,.7); backface-visibility:hidden;
}
.card__media{ position:relative; aspect-ratio:16/9; overflow:hidden; }
.grid--square .card__media{ aspect-ratio:1; }
.card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.card:hover .card__media img{ transform:scale(1.04); }
.card__media .ph{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:7px; text-align:center; padding:16px;
  background:
    radial-gradient(120% 100% at 30% 20%, rgba(84,211,255,.08), transparent 60%),
    linear-gradient(150deg, var(--bg-2), #061522);
  color:var(--muted); font-family:var(--disp); font-weight:500; font-size:.98rem;
}
.card__media .ph small{ font-family:var(--body); font-weight:500; opacity:.55; font-size:.68rem; letter-spacing:.06em; }
.card__label{ display:flex; justify-content:space-between; align-items:center; gap:10px;
  padding:14px 16px; font-weight:600; font-size:.95rem; border-top:1px solid var(--line); }
.card__label small{ color:var(--faint); font-weight:500; font-size:.78rem; }

/* ===== MARQUEE ===== */
/* vertical roll */
.marquee{ height:280px; overflow:hidden;
  -webkit-mask:linear-gradient(180deg,transparent,#000 14%,#000 86%,transparent);
  mask:linear-gradient(180deg,transparent,#000 14%,#000 86%,transparent); }
.marquee__track{ display:flex; flex-direction:column; align-items:center; gap:12px;
  height:max-content; animation:scrollv 30s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
@keyframes scrollv{ from{ transform:translateY(0);} to{ transform:translateY(calc(-50% - 6px));} }
.chip{
  padding:11px 22px; border-radius:999px; font-weight:500; font-size:.95rem; white-space:nowrap;
  color:var(--muted); background:var(--glass); border:1px solid var(--line);
}
@keyframes scroll{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }

/* ===== PRICING ===== */
.grid--price{ display:grid; grid-template-columns:repeat(4,1fr); align-items:stretch; }
.price{
  display:flex; flex-direction:column; min-width:0; padding:30px 24px; border-radius:var(--r);
  background:var(--glass); border:1px solid var(--line);
  transition:transform .25s ease, border-color .25s ease;
}
.price:hover{ transform:translateY(-5px); border-color:var(--line-2); }
.price.is-popular{ border-color:var(--accent); background:var(--glass-2);
  box-shadow:0 0 0 1px rgba(84,211,255,.25), 0 40px 70px -34px rgba(84,211,255,.3); position:relative; }
.price.is-popular::before{
  content:"Most popular"; position:absolute; top:-11px; left:24px;
  background:linear-gradient(180deg,#7fe1ff,var(--accent-2)); color:#03161f;
  font-family:var(--body); font-weight:600; font-size:.7rem; letter-spacing:.04em;
  padding:4px 11px; border-radius:7px;
}
.price__cat{ font-size:.76rem; letter-spacing:.16em; text-transform:uppercase; color:var(--faint); font-weight:600; }
.price h3{ font-size:1.3rem; margin:10px 0 4px; font-weight:600; }
.price__amt{ font-family:var(--disp); font-size:2.3rem; font-weight:600; letter-spacing:-0.03em; line-height:1; margin:8px 0 2px; }
.price__amt small{ font-size:.82rem; color:var(--faint); font-weight:500; font-family:var(--body); }
.price__amt .rbx{ font-size:.58em; color:var(--accent); font-weight:700; vertical-align:.2em; margin-right:2px; font-family:var(--body); }
.price ul{ list-style:none; margin:18px 0 24px; display:flex; flex-direction:column; gap:11px; font-size:.92rem; color:var(--muted); }
.price li{ position:relative; padding-left:24px; }
.price li::before{ content:""; position:absolute; left:2px; top:.55em; width:11px; height:6px;
  border-left:2px solid var(--accent); border-bottom:2px solid var(--accent); transform:rotate(-45deg); }
.price .btn{ margin-top:auto; justify-content:center; }
.pricing__note{ text-align:center; margin-top:30px; color:var(--muted); }
.pricing__note a{ color:var(--accent); font-weight:600; border-bottom:1px solid transparent; transition:.2s; }
.pricing__note a:hover{ border-bottom-color:var(--accent); }

/* ===== CONTACT ===== */
.contact{ text-align:center; }

/* contact method cards */
.contact__cards{ display:grid; grid-template-columns:1fr 1fr; gap:18px;
  max-width:760px; margin:0 auto 22px; }
.ccard{
  display:flex; flex-direction:column; gap:16px; text-align:left;
  padding:26px 24px; border-radius:var(--r);
  background:var(--glass-2); border:1px solid var(--line); box-shadow:var(--shadow);
  transition:transform .2s ease, border-color .2s ease;
}
.ccard:hover{ transform:translateY(-4px); border-color:var(--line-2); }
.ccard__head{ display:flex; gap:14px; align-items:center; }
.ccard__head .i{ width:34px; height:34px; color:var(--accent); flex:none; }
.ccard__head h3{ font-size:1.2rem; }
.ccard__head p{ color:var(--faint); font-size:.88rem; }
.ccard__user{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:10px 14px; border-radius:12px;
  background:rgba(255,255,255,.05); border:1px solid var(--line);
}
.ccard__user code{ font-family:var(--body); font-weight:600; font-size:.98rem; }
.copy{
  border:1px solid var(--line-2); background:rgba(255,255,255,.06); color:var(--text);
  font:600 .8rem var(--body); padding:6px 12px; border-radius:8px; cursor:pointer;
  transition:.2s; white-space:nowrap;
}
.copy:hover{ border-color:var(--accent); background:rgba(84,211,255,.12); }
.ccard .btn{ justify-content:center; margin-top:auto; }
.ccard__hint{ margin-top:auto; color:var(--faint); font-size:.85rem; text-align:center; padding:8px 0; }

/* request builder */
.builder{
  max-width:760px; margin:0 auto; text-align:left;
  padding:30px clamp(20px,4vw,30px); border-radius:var(--r);
  background:var(--glass); border:1px solid var(--line); box-shadow:var(--shadow);
}
.builder__title{ font-size:1.25rem; text-align:center; }
.builder__sub{ color:var(--muted); font-size:.95rem; text-align:center; margin:6px 0 20px; }
.builder__opts{ display:flex; gap:8px; flex-wrap:wrap; justify-content:center; margin-bottom:16px; }
.opt{
  padding:9px 20px; border-radius:999px; font-family:var(--body); font-weight:600; font-size:.92rem;
  cursor:pointer; color:var(--muted); background:rgba(255,255,255,.03);
  border:1px solid var(--line); transition:.2s;
}
.opt:hover{ color:var(--text); border-color:var(--line-2); }
.opt.is-active{ color:#03161f; background:linear-gradient(180deg,#7fe1ff,var(--accent) 60%,var(--accent-2)); border-color:transparent; }
.builder textarea, .builder input{
  width:100%; padding:12px 14px; margin-bottom:12px; border-radius:12px;
  background:rgba(2,16,28,.55); border:1px solid var(--line); color:var(--text);
  font:500 .95rem var(--body); resize:vertical;
}
.builder textarea:focus, .builder input:focus{ outline:none; border-color:var(--accent); }
.builder textarea::placeholder, .builder input::placeholder{ color:var(--faint); }
.builder__preview{
  white-space:pre-wrap; padding:14px 16px; margin-bottom:16px; border-radius:12px;
  background:rgba(2,16,28,.55); border:1px dashed var(--line-2);
  color:var(--muted); font-size:.92rem; line-height:1.55;
}
.builder__actions{ display:flex; gap:12px; flex-wrap:wrap; justify-content:center; }

@media (max-width:640px){
  .contact__cards{ grid-template-columns:1fr; }
}
.contact__card{
  max-width:680px; margin:0 auto; padding:clamp(36px,6vw,60px) clamp(24px,5vw,52px); border-radius:24px;
  background:var(--glass-2); border:1px solid var(--line); box-shadow:var(--shadow);
}
.contact__card h2{ font-size:clamp(1.7rem,3.6vw,2.5rem); margin-top:6px; }
.contact__card p{ color:var(--muted); margin:14px auto 30px; max-width:440px; }
.contact__btns{ display:flex; gap:13px; justify-content:center; flex-wrap:wrap; }

/* ===== FOOTER ===== */
.footer{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px;
  max-width:var(--maxw); margin:0 auto; padding:34px clamp(16px,4vw,28px) 56px;
  border-top:1px solid var(--line); color:var(--faint); font-size:.86rem; }
.footer__logo{ height:30px; width:auto; opacity:.9; filter:drop-shadow(0 2px 5px rgba(0,0,0,.4)); }

/* ===== PAGE ROUTER (tabbed sections, no endless scroll) ===== */
main [data-page]:not(.is-current){ display:none; }
main [data-page].is-current{ animation:pagein .4s ease; }
@keyframes pagein{ from{ opacity:0; transform:translateY(14px);} to{ opacity:1; transform:none;} }
.nav__links a.is-active{ color:var(--text); background:rgba(255,255,255,.07); }
/* non-home pages need room under the fixed nav */
.section[data-page]{ padding-top:140px; min-height:calc(100vh - 220px); }

/* ===== ABOUT ME (lives on the Home page) ===== */
.section--about[data-page]{ padding-top:30px; min-height:auto; }
.about__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:56px; align-items:start;
  max-width:1020px; margin:0 auto; }
.about__copy p{ color:var(--muted); margin-bottom:16px; font-size:1.05rem; }
.about__copy p strong{ color:var(--text); }
.about__facts{ list-style:none; display:flex; flex-wrap:wrap; gap:10px; margin:6px 0 0; }
.about__facts li{
  padding:9px 16px; border-radius:999px; font-size:.9rem; font-weight:600;
  background:var(--glass); border:1px solid var(--line);
}
.about__clients-title{ font-size:1.15rem; font-weight:600; text-align:center; margin-bottom:18px; }

@media (max-width:920px){
  .about__grid{ grid-template-columns:1fr; text-align:center; gap:40px; }
  .about__facts{ justify-content:center; }
}

/* ===== LIGHTBOX ===== */
.card{ cursor:zoom-in; }
.lightbox{
  position:fixed; inset:0; z-index:200; display:none;
  align-items:center; justify-content:center; padding:24px;
  background:rgba(2,8,16,.86); backdrop-filter:blur(6px);
}
.lightbox.is-open{ display:flex; animation:pagein .25s ease; }
.lightbox__fig{ margin:0; display:flex; flex-direction:column; align-items:center; gap:14px; max-width:100%; }
.lightbox__fig img{
  max-width:min(1100px,92vw); max-height:82vh; width:auto; height:auto;
  border-radius:14px; box-shadow:0 40px 90px -30px rgba(0,0,0,.9); border:1px solid var(--line-2);
}
.lightbox__fig figcaption{ color:var(--text); font-weight:600; font-size:1rem; text-align:center; }
.lightbox__close{
  position:absolute; top:16px; right:20px; width:46px; height:46px; border-radius:50%;
  background:rgba(255,255,255,.08); border:1px solid var(--line-2); color:var(--text);
  font-size:1.8rem; line-height:1; cursor:pointer; transition:.2s;
}
.lightbox__close:hover{ background:rgba(255,255,255,.16); border-color:var(--accent); }
body.lb-open{ overflow:hidden; }

/* ===== REVEAL ===== */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .8s cubic-bezier(.2,.6,.2,1), transform .8s cubic-bezier(.2,.6,.2,1); }
.reveal.in{ opacity:1; transform:none; }

/* ===== RESPONSIVE ===== */
@media (max-width:920px){
  .hero__inner{ grid-template-columns:1fr; text-align:center; gap:40px; }
  .hero__copy{ order:2; } .hero__art{ order:1; }
  .hero__avatar{ width:min(82%,340px); }
  .hero__sub{ margin-inline:auto; } .hero__btns,.stats{ justify-content:center; }
  .grid--wide{ grid-template-columns:repeat(2,1fr); }
  .grid--square{ grid-template-columns:repeat(3,1fr); }
  .grid--price{ grid-template-columns:repeat(2,1fr); }
  .price.is-popular::before{ left:50%; transform:translateX(-50%); }
}
@media (max-width:620px){
  .nav__links,.nav__cta{ display:none; }
  .nav.open .nav__links{ display:flex; flex-direction:column; position:absolute; top:100%; right:14px;
    background:rgba(6,20,33,.97); padding:10px; border-radius:14px; gap:2px; border:1px solid var(--line); backdrop-filter:blur(12px); }
  .nav__burger{ display:flex; margin-left:auto; }
  .grid--wide,.grid--square{ grid-template-columns:1fr 1fr; }
  .grid--price,.grid--banner{ grid-template-columns:1fr; }
  .stats{ gap:26px; }
  .footer{ justify-content:center; text-align:center; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; }
  .reveal{ opacity:1; transform:none; }
  .bg__bubbles{ display:none; }
}
