/* ===== Palette ===== */
:root{
  --accent:#50e3a4;
  --accent2:#67b3ff;
  --nav-offset:88px;

  --ink:#0b0f14;
  --panel:#0f141b;
  --surface-0:#0c1117;
  --surface-1:#0f141b;
  --surface-2:#111826;
  --surface-3:#151d2a;
  --muted:#1b2230;
  --line:#1e2633;
  --edge:#2a3446;
  --text:#d7e2f3;
  --headline:#ffffff;
  --sub:#a8b3c2;
  --text-soft:#b7c6d6;
  --text-muted:#9fb1c6;
  --text-dim:#8fa2bc;
  --nav-link:#b6c7da;
  --nav-link-hover:#e1efff;

  --btn-text:#ffffff;
  --btn-bg-start:#172033;
  --btn-bg-end:#111827;
  --ghost-text:#ffffff;
  --ghost-border:#2a344a;

  --hdr-bg:rgba(12,17,23,.78);
  --focus-ring:rgba(103,179,255,.4);
  --shadow:0 14px 40px rgba(0,0,0,.35);
  --theme-color:#0b0f14;
  --space-1:.5rem;
  --space-2:.75rem;
  --space-3:1rem;
  --space-4:1.5rem;
  --space-5:2rem;
  --radius-sm:.65rem;
  --radius-md:.85rem;
  --radius-lg:1.1rem;
  --elev-1:0 12px 28px rgba(0,0,0,.28);
  --elev-2:0 18px 42px rgba(0,0,0,.36);
  --ease-fast:160ms ease;
  --ease-mid:240ms ease;
}

:root[data-theme="dark"]{
  --theme-color:#0b0f14;
}

:root[data-theme="light"]{
  --ink:#f5f8fc;
  --panel:#ffffff;
  --surface-0:#edf2f8;
  --surface-1:#ffffff;
  --surface-2:#f6f9fd;
  --surface-3:#eef3fb;
  --muted:#e6edf7;
  --line:#d6e0ef;
  --edge:#b9c7dc;
  --text:#1f2f45;
  --headline:#0d223c;
  --sub:#4d6280;
  --text-soft:#3f5675;
  --text-muted:#587090;
  --text-dim:#667f9f;
  --nav-link:#3f5675;
  --nav-link-hover:#0d223c;

  --btn-text:#ffffff;
  --btn-bg-start:#2f7ea8;
  --btn-bg-end:#235f88;
  --ghost-text:#19304f;
  --ghost-border:#b9c7dc;

  --hdr-bg:rgba(245,248,252,.88);
  --focus-ring:rgba(66,132,204,.35);
  --shadow:0 14px 40px rgba(20,42,74,.14);
  --theme-color:#f5f8fc;
}
@media(max-width:960px){:root{--nav-offset:76px}}
@media(max-width:640px){:root{--nav-offset:68px}}

/* ===== Base ===== */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{
  scroll-padding-top:var(--nav-offset);
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}
body{
  background:var(--ink);
  color:var(--text);
  font:14px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  min-width:320px;
  overflow-x:clip;
}
@supports not (overflow: clip){
  body{overflow-x:hidden}
}
body h1,
body h2,
body h3,
body h4,
body h5,
body h6{color:var(--headline)}
img{max-width:100%;display:block}
a{color:var(--accent2);text-decoration:none}
a:hover{opacity:.9}
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
summary:focus-visible,
[role="button"]:focus-visible{
  outline:2px solid var(--accent2);
  outline-offset:2px;
}
[id]{scroll-margin-top:var(--nav-offset)}
.skip-link{
  position:absolute;
  left:16px;
  top:-80px;
  background:var(--accent2);
  color:#08111d;
  padding:.55rem 1rem;
  border-radius:.65rem;
  font-weight:600;
  z-index:100;
  transition:top .2s ease;
}
.skip-link:focus{
  top:12px;
  outline:3px solid var(--focus-ring);
}
.wrap{max-width:1440px;margin:0 auto;padding:0 20px}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.7rem 1rem;border-radius:.65rem;border:1px solid var(--edge);
  background:linear-gradient(180deg,var(--btn-bg-start),var(--btn-bg-end));color:var(--btn-text);
  box-shadow:0 0 0 0 rgba(103,179,255,0);transition:.2s ease;cursor:pointer;
  white-space:nowrap;font-weight:600
}
.btn:hover{box-shadow:0 0 0 2px rgba(103,179,255,.15)}
.btn--primary{
  background:linear-gradient(180deg,#3ba980,#2c7d93);
  border-color:#45cba0;
  color:#05211a;
  box-shadow:0 10px 24px rgba(27,202,150,.22)
}
.btn--primary:hover{box-shadow:0 0 0 2px rgba(99,219,180,.45)}
:root[data-theme="light"] .btn--primary{
  background:linear-gradient(180deg,#3f95d4,#2f77b3);
  border-color:#78b8e6;
  color:#f4f9ff;
  box-shadow:0 10px 24px rgba(39,99,157,.3)
}
:root[data-theme="light"] .btn--primary:hover{
  box-shadow:0 0 0 2px rgba(103,179,255,.38)
}
.btn--ghost{background:transparent;color:var(--ghost-text);border-color:var(--ghost-border)}
.btn--xl{padding:.95rem 1.25rem;font-size:15px}
.btn--wide{width:100%}
.btn--theme{min-width:94px;padding:.7rem .9rem}
.btn--theme [data-theme-toggle-icon]{font-size:14px;line-height:1}
.btn--theme-icon{
  min-width:36px;
  width:36px;
  height:36px;
  padding:0;
  border-radius:.6rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.btn--theme-mobile{justify-content:flex-start}
.btn--theme-mobile [data-theme-toggle-icon]{width:1.1rem;display:inline-block;text-align:center}
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* ===== Header ===== */
.hdr{
  position:sticky;top:0;z-index:50;background:var(--hdr-bg);
  border-bottom:1px solid var(--line);backdrop-filter:blur(10px)
}
.hdr__row{display:flex;align-items:center;gap:16px;padding:12px 0}
.brand{
  font-weight:800;color:var(--headline);display:inline-flex;align-items:center;gap:.6rem;font-size:18px
}
.brand__accent{color:var(--accent2)}
.brand--small{font-size:16px;color:var(--headline)}
.spark{width:10px;height:10px;border-radius:50%;background:var(--accent);display:inline-block}
.nav{margin-left:auto;display:flex;gap:18px;align-items:center}
.nav a{
  color:var(--nav-link);
  font-size:16px;
  font-weight:600;
  line-height:1.2;
  display:inline-flex;
  align-items:center;
}
.nav a:hover{color:var(--nav-link-hover)}
.nav .btn--theme-icon{margin-left:2px}
.hdr__cta{display:flex;gap:10px;margin-left:8px}
.burger{display:none;margin-left:10px;background:transparent;border:1px solid var(--edge);color:var(--text-soft);border-radius:.5rem;padding:.35rem .55rem}

/* Mobile nav */
.nav--mobile{display:none;flex-direction:column;padding:10px 20px;border-bottom:1px solid var(--line);background:var(--panel)}
.nav--mobile a,
.nav--mobile button{padding:10px 0;border-top:1px solid rgba(255,255,255,.05)}
.nav--mobile.open{display:flex}

/* ===== Hero ===== */
.hero{
  position:relative;
  padding:64px 0 50px;border-bottom:1px solid var(--line);
  background:
    radial-gradient(800px 360px at 12% -10%, rgba(80,227,164,.10), transparent 60%),
    radial-gradient(900px 360px at 88% 0%, rgba(103,179,255,.10), transparent 60%);
}
.hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:34px;align-items:center}
.pill{
  display:inline-block;background:var(--surface-3);border:1px solid var(--edge);color:var(--sub);
  padding:.32rem .6rem;border-radius:.6rem;font-size:12px;margin-bottom:.6rem
}
.hero h1{margin:.2rem 0 .5rem;font-size:38px;line-height:1.12;letter-spacing:.1px}
.lede{color:var(--text-soft);max-width:50ch}
.hero__cta{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}
.hero__points{list-style:none;margin:16px 0 0;padding:0;color:var(--text-muted)}
.hero__points li{margin:.2rem 0}
.hero__shot{
  border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--surface-2);box-shadow:var(--shadow)
}
.glow{position:absolute;filter:blur(50px);opacity:.4;pointer-events:none}
.glow--mint{width:200px;height:200px;background:radial-gradient(circle, var(--accent) 0%, transparent 60%);left:6%;top:10%}
.glow--blue{width:240px;height:240px;background:radial-gradient(circle, var(--accent2) 0%, transparent 60%);right:8%;top:6%}

/* ===== Split panels ===== */
.split{padding:56px 0;border-bottom:1px solid var(--line);background:var(--panel)}
.split__grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.panel{
  background:linear-gradient(180deg,var(--surface-1),var(--surface-0));border:1px solid var(--line);
  border-radius:14px;padding:20px;box-shadow:0 12px 28px rgba(0,0,0,.28)
}
.panel h2{margin:.2rem 0 .4rem}
.panel p{color:var(--sub)}
.panel--accent{border-color:#2f3f57;box-shadow:0 0 0 1px rgba(103,179,255,.12) inset}
.note{
  margin:.7rem 0 0;background:var(--surface-2);border:1px dashed var(--edge);border-radius:.6rem;padding:.5rem .6rem;color:var(--text-soft)
}
.list{margin:.6rem 0 1rem;color:var(--text-muted);padding-left:1.1rem}
.list li{margin:.25rem 0}

/* ===== Timeline ===== */
.timeline{padding:56px 0;border-bottom:1px solid var(--line)}
.timeline h2{margin:0 0 .8rem}
.steps{list-style:none;margin:0 auto;padding:0;display:grid;grid-template-columns:1fr;gap:12px;max-width:780px}
.steps li{
  display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px
}
.step__badge{
  width:28px;height:28px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,var(--surface-3),var(--surface-2));border:1px solid var(--edge);color:var(--headline);font-weight:700
}
.steps h3{margin:.1rem 0 .2rem}
.learn-callout{margin:18px auto 0;max-width:720px}

/* ===== Showcase ===== */
.showcase{padding:56px 0;border-bottom:1px solid var(--line);background:
  radial-gradient(700px 280px at 80% 20%, rgba(103,179,255,.08), transparent 60%)
}
.showcase h2{margin:0 0 .8rem}
.gallery{
  position:relative;
  overflow:hidden;
  border-radius:14px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,var(--surface-1),var(--surface-0));
  padding:18px 0;
  min-height:240px;
}
.gallery::before,
.gallery::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width:80px;
  pointer-events:none;
  z-index:2;
}
.gallery::before{
  left:0;
  background:linear-gradient(90deg,var(--panel) 0%,rgba(15,20,27,0) 100%);
}
.gallery::after{
  right:0;
  background:linear-gradient(270deg,var(--panel) 0%,rgba(15,20,27,0) 100%);
}
.gallery__viewport{
  overflow:hidden;
  scrollbar-width:none;
  -ms-overflow-style:none;
  padding:0 4px;
}
.gallery__viewport::-webkit-scrollbar{display:none}
.gallery__track{
  display:flex;
  align-items:stretch;
  gap:16px;
  margin:0;
  padding:0 4px;
  list-style:none;
  width:max-content;
  will-change:transform;
}
.gallery__item{
  flex:0 0 240px;
  min-width:0;
  scroll-snap-align:start;
}
.gallery__link{
  display:flex;
  flex-direction:column;
  gap:0;
  height:100%;
  border-radius:12px;
  border:1px solid var(--line);
  background:var(--surface-2);
  color:inherit;
  padding:10px;
  box-shadow:0 10px 24px rgba(0,0,0,.22);
  transition:transform .25s ease, box-shadow .25s ease;
}
.gallery__link:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(0,0,0,.32)}
.gallery__thumb{
  position:relative;
  aspect-ratio:1/1;
  border-radius:10px;
  background:var(--surface-0);
  overflow:hidden;
  border:1px solid var(--edge);
  display:flex;
  align-items:center;
  justify-content:center;
}
.gallery__thumb img{
  width:100%;
  height:100%;
  object-fit:contain;
}
.gallery__controls{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 6px;
  pointer-events:none;
}
.gallery__control{
  pointer-events:auto;
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid var(--edge);
  background:rgba(12,17,23,.85);
  color:var(--headline);
  font-size:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 8px 18px rgba(0,0,0,.35);
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.gallery__control:hover{
  transform:translateY(-2px);
  border-color:rgba(103,179,255,.55);
  box-shadow:0 12px 26px rgba(0,0,0,.4);
}
.gallery__status{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  text-align:center;
  font-size:14px;
  color:var(--text-muted);
  background:linear-gradient(180deg,rgba(8,12,18,.78),rgba(8,12,18,.52));
  z-index:3;
}
.gallery.is-ready .gallery__status{display:none}

/* ===== Custom design ===== */
.custom{padding:56px 0;border-bottom:1px solid var(--line);background:radial-gradient(880px 380px at 90% 10%,rgba(103,179,255,.08),transparent 60%),radial-gradient(720px 320px at 10% 0%,rgba(80,227,164,.08),transparent 65%),var(--panel)}
.custom__card{position:relative;display:grid;grid-template-columns:minmax(0,0.95fr) minmax(0,1.05fr);gap:32px;align-items:start;background:linear-gradient(180deg,rgba(18,29,43,.95),rgba(12,19,29,.92));border:1px solid rgba(114,150,205,.25);border-radius:22px;padding:36px;box-shadow:0 22px 48px rgba(5,12,22,.55);overflow:hidden}
.custom__card::before{content:"";position:absolute;inset:-20% auto auto 55%;width:420px;height:420px;background:radial-gradient(circle at center,rgba(98,165,255,.24),transparent 70%);opacity:.4;pointer-events:none}
.custom__card::after{content:"";position:absolute;inset:auto -25% -40% 20%;width:360px;height:360px;background:radial-gradient(circle at center,rgba(86,226,164,.22),transparent 75%);opacity:.35;pointer-events:none}
.custom__header{position:relative;z-index:1;grid-column:1/-1;display:grid;gap:10px;max-width:760px;margin:0 auto 4px;text-align:center}
.custom__header h2{margin:0}
.custom__header p{margin:0;color:var(--text-soft);line-height:1.6}
.custom__content{position:relative;z-index:1;display:flex;flex-direction:column;gap:1.1rem}
.custom__content h2{margin:0}
.custom__content p{color:var(--text-soft);max-width:60ch}
.custom__price-note{color:var(--accent);font-weight:600;font-size:15px;margin:0 0 16px}
.custom__list{margin:1.1rem 0 0;padding:0;list-style:none;color:var(--text-muted);display:grid;gap:.6rem}
.custom__list li{position:relative;padding-left:1.6rem}
.custom__list li::before{content:"";position:absolute;left:0;top:.45rem;width:.65rem;height:.65rem;border-radius:50%;background:linear-gradient(180deg,#58e0af,#61a7ff);box-shadow:0 0 0 6px rgba(94,173,255,.08)}
.custom__note{margin-top:auto;color:var(--text-dim);max-width:52ch}
.custom__note a{color:inherit;text-decoration:underline dotted}
.custom__form{position:relative;z-index:1}
.custom-form{display:flex;flex-direction:column;gap:18px}
.custom-form__group{display:flex;flex-direction:column;gap:10px;margin:0;padding:0;border:0}
.custom-form__group--upload{gap:14px}
.custom-form__legend{margin:0;font-weight:600;color:#d9e5f8;font-size:13px;text-transform:uppercase;letter-spacing:.12em}
.custom-form__dropzone{position:relative;border:1px dashed rgba(129,177,244,.55);border-radius:16px;padding:26px;text-align:left;background:#0c141f;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 18px 42px rgba(3,9,18,.55)}
.custom-form__dropzone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.custom-form__dropzone-inner{display:flex;flex-direction:column;gap:.5rem;pointer-events:none;width:100%;max-width:320px}
.custom-form__drop-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:14px;background:rgba(120,169,255,.12);color:#9ebdf5}
.custom-form__drop-main{font-weight:600;color:var(--headline);font-size:16px}
.custom-form__drop-sub{color:var(--text-dim);font-size:13px;line-height:1.4}
.custom-form__dropzone.is-drag{border-color:rgba(96,228,178,.85);box-shadow:0 0 0 1px rgba(96,228,178,.45) inset,0 22px 44px rgba(6,19,29,.6);transform:translateY(-1px)}
.custom-form__dropzone.has-file{border-style:solid;border-color:rgba(129,177,244,.8);background:#0e1927}
.custom-form__remove{align-self:flex-start;background:transparent;border:1px solid rgba(111,159,217,.4);color:var(--text-soft);border-radius:999px;padding:.25rem .75rem;font-size:12px;text-transform:uppercase;letter-spacing:.06em;cursor:pointer}
.custom-form__remove:hover{border-color:rgba(111,159,217,.7);color:var(--headline)}
.custom-form__file-info{margin:0;color:#7f90a6;font-size:12px}
.custom-form__label{font-weight:600;color:var(--headline);font-size:13px;text-transform:uppercase;letter-spacing:.08em}
.custom-form__input,
.custom-form__textarea{width:100%;border:1px solid rgba(111,159,217,.35);border-radius:12px;padding:.75rem .9rem;background:rgba(10,16,23,.85);color:#e5efff;font-size:14px;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease}
.custom-form__input:focus,
.custom-form__textarea:focus{outline:none;border-color:rgba(103,179,255,.8);box-shadow:0 0 0 2px rgba(103,179,255,.18)}
.custom-form__textarea{min-height:120px;resize:vertical}
.custom-form__actions{display:flex;flex-direction:column;gap:10px}
.custom-form__status{min-height:1.2em;font-size:13px;color:var(--text-muted);margin:0}
.custom-form__status[data-state="pending"]{color:#bcd3ee}
.custom-form__status[data-state="success"]{color:#50e3a4}
.custom-form__status[data-state="error"]{color:#ff908a}
.custom-form [data-submit][disabled]{cursor:wait;opacity:.8}

/* ===== Custom orders page ===== */
.custom-orders-page{
  background:
    radial-gradient(860px 360px at 92% 6%,rgba(103,179,255,.1),transparent 58%),
    var(--ink);
}
.custom-order-hero{
  position:relative;
  padding:58px 0 46px;
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.custom-order-hero::before{
  display:none;
}
.custom-order-hero__grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(360px,.86fr);
  gap:42px;
  align-items:center;
}
.custom-order-hero__copy h1{
  margin:.2rem 0 .8rem;
  max-width:780px;
  font-size:48px;
  line-height:1.02;
  letter-spacing:0;
}
.custom-order-hero__copy .lede{
  max-width:60ch;
  font-size:17px;
}
.custom-order-hero__cta{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:22px;
}
.custom-order-hero__proof{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin:24px 0 0;
  padding:0;
  max-width:760px;
  list-style:none;
}
.custom-order-hero__proof li{
  min-height:68px;
  display:flex;
  align-items:center;
  padding:12px 14px;
  border:1px solid rgba(103,179,255,.18);
  border-radius:12px;
  background:rgba(16,24,36,.7);
  color:var(--text-soft);
  font-weight:600;
}
.custom-order-request__proof{
  display:grid;
  gap:10px;
  margin:14px 0 0;
  padding:0;
  max-width:520px;
  list-style:none;
}
.custom-order-request__proof li{
  min-height:48px;
  display:flex;
  align-items:center;
  padding:10px 14px;
  border:1px solid rgba(103,179,255,.18);
  border-radius:12px;
  background:rgba(16,24,36,.68);
  color:var(--text-soft);
  font-weight:600;
}
.custom-order-hero__media{
  position:relative;
  min-height:392px;
}
.custom-order-hero__main-img{
  width:min(100%,430px);
  height:auto;
  margin-left:auto;
  border:1px solid rgba(103,179,255,.26);
  border-radius:22px;
  background:var(--surface-1);
  box-shadow:0 30px 72px rgba(0,0,0,.46);
}
.custom-order-hero__mini{
  position:absolute;
  width:31%;
  min-width:132px;
  border:1px solid rgba(103,179,255,.28);
  border-radius:18px;
  background:linear-gradient(180deg,var(--surface-2),var(--surface-0));
  padding:10px;
  box-shadow:0 20px 44px rgba(0,0,0,.36);
}
.custom-order-hero__mini img{
  width:100%;
  height:auto;
  border-radius:12px;
  background:#0a1119;
}
.custom-order-hero__mini--one{
  left:0;
  top:42px;
}
.custom-order-hero__mini--two{
  right:8px;
  bottom:18px;
}
.custom-order-strip{
  padding:12px 0;
  border-bottom:1px solid var(--line);
  background:rgba(15,20,27,.74);
}
.custom-order-strip__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.custom-order-strip__grid div{
  display:flex;
  flex-direction:column;
  gap:4px;
  min-height:74px;
  padding:14px 16px;
  border:1px solid rgba(103,179,255,.16);
  border-radius:14px;
  background:linear-gradient(180deg,rgba(20,31,46,.82),rgba(12,18,28,.76));
}
.custom-order-strip strong{
  color:var(--headline);
  font-size:15px;
}
.custom-order-strip span{
  color:var(--text-muted);
}
.custom-order-section,
.custom-order-workflow,
.custom-order-request{
  padding:64px 0;
  border-bottom:1px solid var(--line);
}
.custom-order-section__head{
  max-width:820px;
  margin:0 auto 26px;
  text-align:center;
}
.custom-order-section__head h2,
.custom-order-workflow__intro h2,
.custom-order-request__copy h2{
  margin:.2rem 0 .55rem;
  font-size:40px;
  line-height:1.12;
  letter-spacing:0;
}
.custom-order-section__head p,
.custom-order-workflow__intro p,
.custom-order-request__copy p{
  color:var(--text-soft);
}
.custom-order-card-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.custom-order-card{
  min-height:220px;
  padding:22px;
  border:1px solid rgba(103,179,255,.18);
  border-radius:16px;
  background:
    linear-gradient(180deg,rgba(19,30,45,.92),rgba(12,18,27,.94));
  box-shadow:0 16px 34px rgba(0,0,0,.28);
}
.custom-order-card__icon{
  display:inline-flex;
  width:42px;
  height:42px;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
  border-radius:12px;
  border:1px solid rgba(103,179,255,.34);
  color:var(--accent2);
  background:rgba(103,179,255,.08);
  font-weight:800;
}
.custom-order-card h3{
  margin:0 0 .45rem;
  font-size:20px;
}
.custom-order-card p{
  margin:0;
  color:var(--text-muted);
}
.custom-order-workflow{
  background:
    radial-gradient(760px 260px at 10% 20%,rgba(103,179,255,.08),transparent 62%),
    var(--panel);
}
.custom-order-workflow__grid{
  display:grid;
  grid-template-columns:minmax(0,.82fr) minmax(0,1.18fr);
  gap:32px;
  align-items:start;
}
.custom-order-workflow__intro{
  position:sticky;
  top:calc(var(--nav-offset) + 24px);
}
.custom-order-steps{
  display:grid;
  gap:14px;
  margin:0;
  padding:0;
  list-style:none;
}
.custom-order-steps li{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:16px;
  padding:20px;
  border:1px solid var(--line);
  border-radius:16px;
  background:linear-gradient(180deg,var(--surface-1),var(--surface-0));
  box-shadow:0 14px 30px rgba(0,0,0,.22);
}
.custom-order-steps span{
  width:38px;
  height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  border:1px solid rgba(103,179,255,.36);
  background:rgba(103,179,255,.1);
  color:var(--accent2);
  font-weight:800;
}
.custom-order-steps h3{
  margin:0 0 .25rem;
}
.custom-order-steps p{
  margin:0;
  color:var(--text-muted);
}
.custom-order-request{
  padding-top:36px;
  background:
    radial-gradient(860px 380px at 82% 12%,rgba(103,179,255,.08),transparent 62%),
    var(--surface-0);
}
.custom-order-request__grid{
  display:grid;
  grid-template-columns:minmax(0,.78fr) minmax(360px,1fr);
  gap:34px;
  align-items:start;
}
.custom-order-price-box{
  display:flex;
  flex-direction:column;
  gap:6px;
  max-width:520px;
  margin-top:22px;
  padding:18px;
  border:1px dashed rgba(103,179,255,.38);
  border-radius:14px;
  background:rgba(103,179,255,.08);
  color:var(--text-soft);
}
.custom-order-price-box strong{
  color:var(--headline);
}
.custom-order-form{
  padding:24px;
  border:1px solid rgba(103,179,255,.22);
  border-radius:18px;
  background:linear-gradient(180deg,rgba(18,29,43,.96),rgba(11,17,26,.96));
  box-shadow:0 24px 54px rgba(0,0,0,.38);
}
.custom-order-faq{
  background:var(--ink);
}
.custom-orders-page .btn--primary{
  background:linear-gradient(180deg,#376b9f,#224d7a);
  border-color:#426f9e;
  color:#f2f7ff;
  box-shadow:0 10px 22px rgba(32,82,132,.22);
}
.custom-orders-page .btn--primary:hover{
  box-shadow:0 0 0 2px rgba(103,179,255,.28);
}

/* ===== Pricing ===== */
.pricing{padding:56px 0;border-bottom:1px solid var(--line)}
.pricing h2{margin:0 0 .4rem}
.center{text-align:center}
.muted{color:var(--sub)}
.pricing__grid{margin-top:18px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.price{
  background:linear-gradient(180deg,var(--surface-2),var(--surface-0));border:1px solid var(--line);
  border-radius:12px;padding:18px;box-shadow:var(--shadow)
}
.price--best{box-shadow:0 0 0 1px rgba(103,179,255,.22) inset}
.price h3{margin:.1rem 0 .15rem;font-size:24px;font-weight:800;letter-spacing:-.01em}
.price__amount{margin:.05rem 0 0;font-size:20px;font-weight:700;color:var(--headline)}
.price__per{margin:.35rem 0 0;font-size:12px;color:var(--text-muted)}
.price .small{color:var(--text-muted);margin:.1rem 0 .7rem}
.callout{
  margin:14px auto 0;max-width:780px;text-align:center;
  background:var(--surface-2);border:1px dashed var(--edge);border-radius:.6rem;padding:.6rem .8rem;color:var(--text-soft)
}

/* ===== FAQ ===== */
.faq{padding:56px 0}
.faq h2{margin:0 0 .8rem}
.faq details{
  border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin:10px 0;background:var(--panel)
}
.faq summary{cursor:pointer;color:var(--headline)}
.faq p{color:var(--sub);margin:.5rem 0 0}

/* ===== Footer ===== */
.ftr{border-top:1px solid var(--line);background:var(--surface-0);padding:22px 0 8px}
.ftr__grid{display:flex;align-items:flex-start;justify-content:space-between;gap:24px}
.ftr__about{max-width:440px}
.ftr__links{display:flex;gap:16px}
.ftr__links a{color:var(--sub)}
.ftr__links a:hover{color:var(--headline)}
.ftr__copy{color:var(--text-dim);padding:10px 0 0;font-size:12px}

/* ===== Responsive ===== */
@media (max-width: 980px){
  .nav{display:none}
  .burger{display:inline-block}
  .hdr__row{gap:10px;padding:10px 0}
  .brand{font-size:17px;gap:.5rem;min-width:0}
  .hdr__cta{margin-left:auto;gap:8px;min-width:0}
  .hdr__cta .btn{padding:.62rem .8rem;font-size:13px}
  .burger{margin-left:0}
  .hero__grid{grid-template-columns:1fr;gap:20px}
  .split__grid{grid-template-columns:1fr}
  .custom__card{grid-template-columns:1fr;padding:28px}
  .custom-order-hero{padding:56px 0 48px}
  .custom-order-hero__grid,
  .custom-order-workflow__grid,
  .custom-order-request__grid{grid-template-columns:1fr}
  .custom-order-hero__copy h1{font-size:48px}
  .custom-order-section__head h2,
  .custom-order-workflow__intro h2,
  .custom-order-request__copy h2{font-size:34px}
  .custom-order-hero__media{min-height:420px;max-width:620px;margin:0 auto;width:100%}
  .custom-order-hero__main-img{margin:0 auto}
  .custom-order-hero__proof,
  .custom-order-strip__grid,
  .custom-order-card-grid{grid-template-columns:1fr}
  .custom-order-hero__proof li{min-height:auto}
  .custom-order-workflow__intro{position:static}
  .gallery{min-height:220px}
  .gallery__item{flex-basis:200px}
  .pricing__grid{grid-template-columns:1fr}
}
@media (max-width: 680px){
  .wrap{padding:0 16px}
  .brand{font-size:16px}
  .hdr__cta .btn{padding:.56rem .7rem;font-size:12.5px}
  .ftr__grid{flex-direction:column}
  .ftr__links{flex-wrap:wrap;gap:10px 16px}
  .custom{padding:48px 0}
  .custom__card{padding:24px;gap:24px}
  .custom-order-hero__copy h1{font-size:36px}
  .custom-order-section__head h2,
  .custom-order-workflow__intro h2,
  .custom-order-request__copy h2{font-size:30px}
  .custom-order-hero__copy .lede{font-size:15px}
  .custom-order-hero__media{min-height:360px}
  .custom-order-hero__mini{min-width:118px;padding:7px;border-radius:14px}
  .custom-order-section,
  .custom-order-workflow,
  .custom-order-request{padding:48px 0}
  .custom-order-card{min-height:auto}
  .custom-order-form{padding:20px}
  .custom-form__dropzone{padding:22px}
  .custom-form__drop-icon{width:42px;height:42px}
}
@media (max-width: 560px){
  .wrap{padding:0 14px}
  .hdr__row{gap:8px;padding:9px 0}
  .brand{font-size:15px;gap:.42rem}
  .hdr__cta{gap:6px}
  .hdr__cta .btn{padding:.5rem .62rem;font-size:12px}
  .hdr__cta .btn--ghost:not([href="/designs/"]){display:none}
  .nav--mobile{padding:8px 14px}
  .hero h1{font-size:30px}
  .hero__cta{flex-direction:column}
  .custom-order-hero__cta{flex-direction:column}
  .custom-order-hero__media{min-height:330px}
  .custom-order-hero__mini--one{top:22px}
  .custom-order-hero__mini--two{bottom:6px}
  .gallery{min-height:200px}
  .gallery__item{flex-basis:160px}
}

@media (prefers-reduced-motion: reduce){
  .gallery__track{transition:none!important;transform:none!important}
}

/* Learn */
.learn-main{padding:56px 0 80px}
.learn-main .wrap{display:flex;flex-direction:column;gap:28px}
.learn-intro{max-width:720px;color:var(--text-soft)}
.learn-section{border:1px solid var(--line);border-radius:16px;padding:26px 24px;background:linear-gradient(180deg,var(--surface-1),var(--surface-0))}
.learn-section + .learn-section{margin-top:12px}
.learn-section h2{margin:0 0 1rem;font-size:24px}
.guide-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.guide-card{display:flex;flex-direction:column;gap:12px;padding:18px;border:1px solid var(--line);border-radius:14px;background:var(--panel);box-shadow:0 10px 24px rgba(0,0,0,.22)}
.guide-card h3{margin:0;font-size:18px}
.guide-card__link{display:block;text-align:center}
.guide-card__link img{margin:0 auto;border-radius:8px}
.guide-card__excerpt{margin:0;color:var(--text-muted)}
.guide-card__meta{margin-top:auto;display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--text-dim)}
.guide-card__cta{font-weight:600;color:var(--accent2);font-size:13px}
.guide-card__cta:hover{color:var(--headline)}
.guide-card__cta::after{content:" →";transition:.2s}
.guide-card__cta:hover::after{transform:translateX(2px)}
.breadcrumbs{font-size:13px;color:var(--text-dim)}
.breadcrumbs ol{list-style:none;display:flex;align-items:center;gap:8px;margin:0;padding:0}
.breadcrumbs li{display:flex;align-items:center;gap:8px}
.breadcrumbs li::after{content:"›";color:#51607a}
.breadcrumbs li:last-child::after{content:""}
.breadcrumbs a{color:var(--accent2)}
.breadcrumbs li[aria-current="page"]{color:var(--headline)}
.toc{border:1px solid var(--line);border-radius:12px;padding:18px;background:var(--panel)}
.toc__title{margin:0 0 .6rem;font-size:16px;color:var(--headline)}
.toc ol{margin:0;padding-left:1.1rem;display:flex;flex-direction:column;gap:.35rem;color:var(--sub);font-size:14px}
.toc a{color:var(--accent2)}
.guide-layout{display:grid;grid-template-columns:minmax(0,1fr);gap:28px}
.guide{max-width:760px}
.guide-layout--solo{grid-template-columns:minmax(0,1fr)}
.guide--full{max-width:none}
.guide__header h1{margin:0 0 .5rem;font-size:32px}
.guide__header p{margin:0 0 1.2rem;color:var(--text-soft);font-size:16px}
.guide__meta{margin:.4rem 0 1.2rem;color:var(--text-dim);font-size:14px}
.guide__step{margin:40px 0 0}
.guide__step h2{margin:0 0 .6rem;font-size:22px}
.guide__step p{margin:.4rem 0 0;color:var(--text-soft)}
.guide__step img{margin:1rem 0 0;border:1px solid var(--line);border-radius:12px;background:var(--surface-0)}
.learn-guide .guide .custom{padding:28px 0;border-bottom:0;background:none}
.learn-guide .guide .custom__card{padding:26px}
.learn-guide .guide .custom__content p{max-width:none}
.guide-cta{
  background: radial-gradient(circle at 30% 20%, rgba(103,179,255,0.16), rgba(15,20,30,0.9));
  border: 1px solid rgba(103, 179, 255, 0.14);
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.35);
  border-radius: 16px;
  padding: 18px 20px;
  min-width: 240px;
  max-width: 320px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-self: start;
  position: sticky;
  top: 110px;
  z-index: 10;
}
.guide-cta h2{
  margin:0 0 .6rem;
  font-size:18px;
  position: relative;
  padding-left: 12px;
}
.guide-cta h2::before{
  content:"";
  position:absolute;
  left:0;
  top:4px;
  width:4px;
  height:calc(100% - 8px);
  border-radius:6px;
  background:linear-gradient(180deg,#67b3ff,#50e3a4);
}
.guide-cta p{
  margin:0 0 1rem;
  color:#c8d4e3;
  font-size:14px;
}
.guide-faq{margin:48px 0 0}
.guide-faq h2{margin:0 0 .6rem;font-size:22px}
.guide-faq details{border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin:12px 0;background:var(--panel)}
.guide-faq summary{cursor:pointer;color:var(--headline);font-weight:600}
.guide-faq p{margin:.6rem 0 0;color:var(--sub)}
.guide-next{margin:48px 0 0;border-top:1px solid var(--line);padding-top:24px}
.guide-next h2{margin:0 0 1rem;font-size:20px}
.guide-next ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.guide-next a{font-weight:600}
.guide-next p{margin:.2rem 0 0;color:var(--text-muted);font-size:14px}
.guide-next li{border:1px solid var(--line);border-radius:12px;padding:16px;background:var(--panel)}

/* Learn: responsive images without srcset */
.guide img,
.guide__header img,
.guide-step img {
  display:block;
  max-width:100%;
  height:auto;
}

@media (min-width: 960px){
  .guide-layout{grid-template-columns:minmax(0,1fr) 260px}
  .guide-layout--solo{grid-template-columns:minmax(0,1fr)}
}

@media (max-width: 720px){
  .learn-section{padding:22px 18px}
  .guide-cta{position:static}
  .guide__header h1{font-size:28px}
}


:root[data-theme="light"] .gallery::before{
  background:linear-gradient(90deg,var(--panel) 0%,rgba(255,255,255,0) 100%);
}

:root[data-theme="light"] .gallery::after{
  background:linear-gradient(270deg,var(--panel) 0%,rgba(255,255,255,0) 100%);
}

:root[data-theme="light"] .gallery__status{
  background:linear-gradient(180deg,rgba(245,248,252,.82),rgba(245,248,252,.62));
}

:root[data-theme="light"] .custom__card{
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(241,247,255,.94));
  border:1px solid rgba(71,124,196,.25);
}

:root[data-theme="light"] .custom__price-note{
  color:var(--accent2);
}

:root[data-theme="light"] .custom__list li::before{
  background:linear-gradient(180deg,#79bfff,#569ee8);
  box-shadow:0 0 0 6px rgba(104,166,230,.14);
}

:root[data-theme="light"] .custom-form__dropzone{
  background:linear-gradient(180deg,#f8fbff,#eef4fc);
  border-color:rgba(122,166,220,.62);
  box-shadow:0 16px 34px rgba(21,48,84,.18);
}

:root[data-theme="light"] .custom-form__dropzone.is-drag{
  border-color:rgba(90,157,225,.82);
  box-shadow:0 0 0 1px rgba(90,157,225,.35) inset,0 20px 36px rgba(22,47,81,.2);
}

:root[data-theme="light"] .custom-form__dropzone.has-file{
  border-color:rgba(114,161,220,.86);
  background:#edf4fd;
}

:root[data-theme="light"] .custom-form__drop-icon{
  background:rgba(66,132,204,.12);
  color:#6e9fda;
}

:root[data-theme="light"] .custom-form__legend,
:root[data-theme="light"] .custom-form__label{
  color:#294666;
}

:root[data-theme="light"] .custom-form__drop-main{
  color:#0d2747;
}

:root[data-theme="light"] .custom-form__drop-sub,
:root[data-theme="light"] .custom-form__file-info{
  color:#597493;
}

:root[data-theme="light"] .custom-form__input,
:root[data-theme="light"] .custom-form__textarea{
  border-color:rgba(114,154,199,.6);
  background:#ffffff;
  color:#102a47;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.85),0 4px 10px rgba(29,58,92,.07);
}

:root[data-theme="light"] .custom-form__input::placeholder,
:root[data-theme="light"] .custom-form__textarea::placeholder{
  color:#6a85a5;
}

:root[data-theme="light"] .custom-form__input:focus,
:root[data-theme="light"] .custom-form__textarea:focus{
  border-color:rgba(69,142,215,.85);
  box-shadow:0 0 0 2px rgba(66,132,204,.18),0 8px 16px rgba(23,52,88,.08);
}

:root[data-theme="light"] .custom-form__remove{
  border-color:rgba(120,161,205,.55);
  color:#315377;
  background:rgba(255,255,255,.7);
}

:root[data-theme="light"] .custom-orders-page{
  background:
    radial-gradient(900px 420px at 12% 4%,rgba(47,126,168,.08),transparent 60%),
    radial-gradient(860px 360px at 92% 6%,rgba(103,179,255,.12),transparent 58%),
    var(--ink);
}

:root[data-theme="light"] .custom-order-hero__proof li,
:root[data-theme="light"] .custom-order-request__proof li,
:root[data-theme="light"] .custom-order-strip__grid div,
:root[data-theme="light"] .custom-order-card,
:root[data-theme="light"] .custom-order-steps li,
:root[data-theme="light"] .custom-order-form{
  background:linear-gradient(180deg,#ffffff,#f3f7fc);
  border-color:#d2dfef;
  box-shadow:0 16px 34px rgba(30,64,105,.12);
}

:root[data-theme="light"] .custom-order-strip{
  background:rgba(245,248,252,.82);
}

:root[data-theme="light"] .custom-order-workflow{
  background:
    radial-gradient(760px 260px at 10% 20%,rgba(47,126,168,.08),transparent 62%),
    var(--panel);
}

:root[data-theme="light"] .custom-order-request{
  background:
    radial-gradient(860px 380px at 82% 12%,rgba(47,126,168,.08),transparent 62%),
    var(--surface-0);
}

:root[data-theme="light"] .custom-order-price-box{
  border-color:rgba(47,126,168,.42);
  background:rgba(47,126,168,.08);
}

:root[data-theme="light"] .custom-order-hero__mini img{
  background:#eef4fb;
}

:root[data-theme="light"] .custom-orders-page .btn--primary{
  background:linear-gradient(180deg,#3f7cad,#2d5f91);
  border-color:#5f8dbb;
  color:#f4f9ff;
  box-shadow:0 10px 22px rgba(39,99,157,.22);
}

:root[data-theme="light"] .guide-cta{
  background:radial-gradient(circle at 30% 20%, rgba(103,179,255,0.14), rgba(255,255,255,0.96));
}

:root[data-theme="light"] .guide-cta h2{
  color:#0d223c;
}

:root[data-theme="light"] .guide-cta p{
  color:#3f5675;
}

:root[data-theme="light"] .nav--mobile a,
:root[data-theme="light"] .nav--mobile button{
  border-top:1px solid var(--line);
}
