:root{
  --bg:#f4f6fb;
  --surface:#ffffff;
  --ink:#0b1f44;
  --ink-2:#21314f;
  --muted:#5f6e89;
  --line:#dde4ee;
  --soft:#eef2f8;
  --brand:#42b4b4;
  --brand-2:#54c8c8;
  --brand-deep:#2a6b6b;
  --accent:#f18625;
  --accent-2:#d67114;
  --danger:#b91c1c;
  --ok:#0f7a3a;
  --shadow:0 24px 48px -28px rgba(11,31,68,.35);
  --radius:0;
  --radius-lg:0;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',system-ui,-apple-system,'Segoe UI',Arial,sans-serif;background:var(--bg);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%}
h1,h2,h3,h4{font-family:'Inter',system-ui,sans-serif;color:var(--ink);letter-spacing:-.01em;line-height:1.15;margin:0 0 12px}
h1{font-size:clamp(26px,2.7vw,34px);font-weight:800}
h2{font-size:22px;font-weight:800}
h3{font-size:17px;font-weight:700}
p{margin:0 0 12px}
small{color:var(--muted)}

.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* Public storefront theme */
.public-site{
  --bg:#f4fbfd;
  --surface:#ffffff;
  --ink:#1a4b4b;
  --ink-2:#1b4058;
  --muted:#61778a;
  --line:#d7e8ef;
  --soft:#e8f8fb;
  --brand:#42b4b4;
  --brand-2:#54c8c8;
  --brand-deep:#2a6b6b;
  --accent:#f18625;
  --accent-2:#d67114;
  --shadow:0 22px 54px -34px rgba(42,107,107,.36);
  background:
    radial-gradient(900px 420px at 8% 0%,rgba(84,200,200,.13),transparent 60%),
    linear-gradient(180deg,#f7fdff 0%,#f2f8fb 48%,#ffffff 100%);
}
.public-site .site-header{position:sticky;top:0;z-index:40;background:#fff;border-bottom:1px solid rgba(42,107,107,.08);box-shadow:0 14px 36px -34px rgba(42,107,107,.55)}
.top-strip{background:linear-gradient(90deg,#2a6b6b 0%,#42b4b4 52%,#54c8c8 100%);color:#dff9ff}
.top-strip-in{min-height:32px;display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:12px;font-weight:700}
.top-contact,.top-links{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.top-contact a,.top-links a{color:#effdff}
.top-links a:hover,.top-contact a:hover{color:#fff}
.lang-pill{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:26px;border:1px solid rgba(255,255,255,.35);border-radius:3px;background:rgba(255,255,255,.12);font-weight:800;color:#fff}
.main-header{background:rgba(255,255,255,.96);backdrop-filter:saturate(150%) blur(10px)}
.main-header-in{min-height:74px;display:grid;grid-template-columns:220px minmax(240px,1fr) auto;align-items:center;gap:18px}
.site-brand .brand-mark{width:46px;height:46px;border-radius:3px;background:linear-gradient(135deg,#54c8c8,#2a6b6b);font-size:21px;box-shadow:0 18px 36px -26px rgba(42,107,107,.7)}
.site-brand{font-size:18px;letter-spacing:-.02em}
.site-brand small{letter-spacing:.22em;color:#5c7b8d}
.site-search{height:46px;display:grid;grid-template-columns:minmax(0,1fr) 46px;align-items:center;border:1px solid #d7e8ef;border-radius:3px;background:#fff;box-shadow:inset 0 0 0 3px rgba(66,180,180,.04),0 18px 42px -36px rgba(42,107,107,.5);overflow:hidden}
.site-search input{height:100%;min-width:0;border:0;background:transparent;padding:0 18px;font:inherit;font-size:15px;color:var(--ink)}
.site-search input:focus{outline:none}
.site-search button{width:38px;height:38px;margin-right:4px;border:0;border-radius:3px;background:linear-gradient(135deg,#54c8c8,#42b4b4);color:#fff;font-size:21px;font-weight:800;cursor:pointer;box-shadow:0 12px 24px -16px rgba(42,107,107,.65)}
.site-actions{display:flex;align-items:center;gap:10px;white-space:nowrap}
.site-action-link{font-weight:800;color:var(--ink-2)}
.cart-chip{padding:2px 8px;font-size:11px;background:#e8f8fb;color:#42b4b4;border-color:#bfe9f1}
.category-bar{background:#fff;border-top:1px solid rgba(42,107,107,.06);border-bottom:1px solid rgba(42,107,107,.08)}
.category-scroll{overflow-x:auto;scrollbar-width:none}
.category-scroll::-webkit-scrollbar{display:none}
.category-nav{display:flex;gap:7px;min-width:max-content;padding:11px 24px}
.category-nav a{min-width:145px;text-align:center;padding:11px 15px;border-radius:3px;background:#2e7474;color:#fff;font-size:14px;font-weight:800;letter-spacing:.01em;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08),0 16px 30px -28px rgba(42,107,107,.75);transition:transform .16s ease,background .16s ease,box-shadow .16s ease}
.category-nav a:hover{transform:translateY(-1px);background:#368e8e}
.category-nav a.active{background:linear-gradient(135deg,#54c8c8,#42b4b4);box-shadow:0 16px 36px -24px rgba(66,180,180,.85)}
.site-main{min-height:60vh}

/* Storefront home */
.store-hero{position:relative;overflow:hidden;padding:76px 0;background:radial-gradient(800px 360px at 78% 8%,rgba(84,200,200,.24),transparent 62%),linear-gradient(135deg,#1a4b4b 0%,#368e8e 58%,#4ec0c0 100%);color:#fff}
.store-hero::after{content:"";position:absolute;inset:auto -8% -42% 44%;height:520px;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 64%);pointer-events:none}
.store-hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr .9fr;gap:54px;align-items:center}
.store-hero h1{color:#fff;font-size:clamp(36px,4.8vw,62px);line-height:1.02;letter-spacing:-.04em}
.store-hero .lead{max-width:650px;margin-top:18px;color:#d8f5fb;font-size:19px}
.store-hero .label{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:#9cf4ff}
.hero-ghost{background:rgba(255,255,255,.1)!important;color:#fff!important;border-color:rgba(255,255,255,.26)!important}
.showcase-panel{position:relative;border-radius:3px;padding:26px;background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.06));border:1px solid rgba(255,255,255,.18);box-shadow:0 60px 120px -54px rgba(0,0,0,.72);backdrop-filter:blur(8px)}
.showcase-topline,.showcase-specs{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#d8f5fb;font-weight:800}
.showcase-topline small{color:#9cf4ff;text-transform:uppercase;letter-spacing:.16em}
.showcase-sign{position:relative;margin-top:26px;padding:42px 34px 34px;background:#133131;border-radius:3px;border:1px solid rgba(255,255,255,.1);min-height:330px;display:grid;place-items:center}
.showcase-frame{position:relative;width:100%;aspect-ratio:16/7;border-radius:3px;background:linear-gradient(135deg,#2e7474,#1f5353);border:8px solid #0d2222;display:grid;place-items:center;overflow:hidden;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08),0 0 46px rgba(84,200,200,.22)}
.showcase-frame::before{content:"";position:absolute;inset:16px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.08) 0 1px,transparent 1px 46px);opacity:.25}
.showcase-glow{position:absolute;inset:18%;background:radial-gradient(circle,rgba(84,200,200,.35),transparent 62%);filter:blur(10px)}
.showcase-frame strong{position:relative;font-size:clamp(34px,5vw,64px);letter-spacing:.04em;color:#fff;text-shadow:0 0 20px rgba(156,244,255,.8)}
.showcase-frame small{position:absolute;bottom:20px;color:#9cf4ff;letter-spacing:.22em;font-weight:800}
.showcase-ruler{position:absolute;color:#9bb7c8;font-size:12px;font-weight:800;letter-spacing:.12em}
.showcase-ruler.top{top:18px;left:50%;transform:translateX(-50%)}
.showcase-ruler.left{left:12px;top:50%;transform:translateY(-50%) rotate(-90deg)}
.showcase-specs{margin-top:18px;justify-content:flex-start;flex-wrap:wrap}
.showcase-specs span{padding:8px 12px;border-radius:3px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);font-size:12px}
.store-section{padding:42px 0 56px}
.store-section-head{display:flex;align-items:end;justify-content:space-between;gap:18px;margin-bottom:26px}
.store-section-head h2,.catalog-hero h1{margin-top:10px}
.product-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.store-product-card{display:flex;flex-direction:column;min-height:100%;background:#fff;border:1px solid rgba(42,107,107,.1);border-radius:3px;overflow:hidden;color:inherit;box-shadow:0 18px 42px -34px rgba(42,107,107,.45);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}
.store-product-card:hover{transform:translateY(-4px);border-color:#7fd6d6;box-shadow:0 28px 58px -36px rgba(42,107,107,.62)}
.product-visual{position:relative;min-height:178px;padding:0;background:linear-gradient(135deg,#2a6b6b,#1f5353);display:grid;place-items:center;overflow:hidden}
.product-visual::before{content:"";position:absolute;inset:0;background:radial-gradient(340px 190px at 80% -10%,rgba(84,200,200,.28),transparent 60%),linear-gradient(135deg,rgba(255,255,255,.08),transparent 44%);pointer-events:none}
.product-visual.tone-2{background:linear-gradient(135deg,#368e8e,#2e7474)}
.product-visual.tone-3{background:linear-gradient(135deg,#368e8e,#0c7e92)}
.product-visual.tone-4{background:linear-gradient(135deg,#2a6b6b,#42b4b4)}
.product-badge{position:absolute;left:12px;top:12px;z-index:2;padding:6px 10px;border-radius:3px;background:#f18625;color:#fff;font-size:10px;font-weight:900;letter-spacing:.12em}
.product-badge.secondary{top:43px;background:#2a6b6b;color:#dff9ff}
.product-illustration{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.sign-miniature{position:relative;z-index:1;width:86%;aspect-ratio:16/9;border-radius:3px;background:rgba(255,255,255,.92);border:8px solid rgba(4,17,30,.78);display:grid;place-items:center;padding:18px;text-align:center;box-shadow:0 18px 40px -24px rgba(0,0,0,.8),0 0 34px rgba(84,200,200,.28)}
.sign-miniature span{font-size:clamp(17px,1.8vw,25px);font-weight:900;color:#1a4b4b;line-height:1.1}
.product-info{padding:16px 16px 18px;display:flex;flex-direction:column;gap:8px;min-height:178px}
.product-kicker{font-size:10px;line-height:1.4;color:#42b4b4;font-weight:900;letter-spacing:.12em;text-transform:uppercase}
.product-info h3{font-size:18px;margin:0}
.product-info p{color:var(--muted);font-size:13px}
.product-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:auto}
.product-foot strong{font-size:18px;color:#42b4b4;letter-spacing:-.03em}
.product-foot span{font-weight:900;color:#2a6b6b}
.proof-strip{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.proof-item{padding:24px;border:1px solid var(--line);border-radius:3px;background:linear-gradient(180deg,#fff,#f7fdff);box-shadow:0 18px 44px -38px rgba(42,107,107,.4)}

/* Category listing */
.catalog-hero{padding:30px 0;background:linear-gradient(135deg,#e8f8fb,#fff 56%,#effbff)}
.catalog-hero-in{display:flex;align-items:center;justify-content:space-between;gap:20px}
.catalog-hero p{max-width:760px;color:var(--muted);font-size:15px}
.catalog-page{padding:24px 0 54px}
.catalog-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.filter-group,.view-tools{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.filter-pill,.view-tools{min-height:44px;border:1px solid var(--line);border-radius:3px;background:#fff;box-shadow:0 14px 32px -28px rgba(42,107,107,.4)}
.filter-pill{display:inline-flex;align-items:center;padding:0 18px;font-weight:900;color:#2a6b6b}
select.filter-pill{display:inline-block;width:auto;max-width:100%;min-width:150px;height:44px;padding:0 18px;font:inherit;font-weight:900;cursor:pointer}
select.filter-pill:focus{outline:2px solid rgba(8,127,160,.18);border-color:#8dd8e8}
.view-tools{padding:0 10px 0 18px;color:#2a6b6b;font-weight:800}
.view-button{display:inline-grid;place-items:center;width:36px;height:34px;border:0;border-radius:3px;background:transparent;color:#42b4b4;font:inherit;font-weight:900;cursor:pointer}
.view-button.active{background:#e8f8fb;color:#2a6b6b}
.catalog-products .product-visual{min-height:190px}
.catalog-products.is-grid-view{grid-template-columns:repeat(4,minmax(0,1fr))}
.catalog-products.is-list-view{grid-template-columns:1fr}
.catalog-products.is-list-view .store-product-card{display:grid;grid-template-columns:minmax(220px,320px) minmax(0,1fr);min-height:0}
.catalog-products.is-list-view .store-product-card:hover{transform:translateY(-2px)}
.catalog-products.is-list-view .product-visual{min-height:210px;height:100%}
.catalog-products.is-list-view .product-info{min-height:0;padding:18px 20px}
.catalog-products.is-list-view .product-foot{justify-content:flex-start}
.catalog-products.is-list-view .product-foot strong{font-size:20px}
.catalog-products.is-list-view .product-foot span{margin-left:auto}
.home-catalog{padding-top:24px}
.home-catalog-toolbar{margin-bottom:18px}

/* Header */
.header{position:sticky;top:0;z-index:30;background:rgba(255,255,255,.95);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
.header-in{height:68px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;color:var(--ink)}
.brand-mark{width:40px;height:40px;border-radius:3px;background:linear-gradient(135deg,var(--brand-2),var(--brand-deep));color:#fff;display:grid;place-items:center;font-weight:800;letter-spacing:.5px;box-shadow:0 8px 20px -10px rgba(11,31,68,.5)}
.brand small{display:block;font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.16em;text-transform:uppercase;margin-top:2px}
.nav{display:flex;gap:8px}
.nav a{padding:10px 14px;border-radius:3px;color:var(--ink-2);font-weight:600}
.nav a:hover,.nav a.active{background:var(--soft);color:var(--brand)}
.header-cta{display:flex;align-items:center;gap:10px}

/* Buttons */
.btn,.btn-primary,.btn-ghost,.btn-accent,.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:3px;border:1px solid transparent;font-weight:700;cursor:pointer;transition:all .15s ease;font-size:14px;line-height:1}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-deep)}
.btn-accent{background:var(--accent);color:#1b2435}
.btn-accent:hover{background:var(--accent-2)}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink-2)}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand)}
.btn-danger{background:#fff;border-color:#f5c4c4;color:var(--danger)}
.btn-danger:hover{background:#fff1f1}
.btn:disabled,.btn-primary:disabled,.btn-ghost:disabled{opacity:.5;cursor:not-allowed}

/* Cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:3px;box-shadow:var(--shadow)}
.p{padding:20px}
.p-sm{padding:16px}
.section{padding:52px 0}
.section-sm{padding:32px 0}

/* Helpers */
.label{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--brand);background:var(--soft);padding:5px 10px;border-radius:3px}
.muted{color:var(--muted)}
.chip{display:inline-flex;align-items:center;border-radius:3px;border:1px solid var(--line);padding:6px 12px;font-size:12px;font-weight:700;color:var(--muted);background:#fff}
.divider{height:1px;background:var(--line);margin:24px 0}
.flex{display:flex;align-items:center;gap:12px}
.between{justify-content:space-between}
.right{margin-left:auto}

/* Forms */
.input,select,textarea{width:100%;border:1px solid var(--line);border-radius:3px;background:#fff;padding:12px 14px;color:var(--ink);font:inherit;transition:border-color .15s,box-shadow .15s}
.input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(31,58,115,.12)}
textarea{min-height:110px;resize:vertical}
label{display:block;font-size:13px;font-weight:600;color:var(--ink-2);margin-bottom:6px}
label .input,label select,label textarea{margin-top:6px}

/* Grid */
.grid{display:grid;gap:20px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}

/* Hero */
.hero{position:relative;background:radial-gradient(1100px 500px at 80% -10%,rgba(241,134,37,.22),transparent 60%),linear-gradient(135deg,#0a1a3a 0%,#1b3578 60%,#2c4f9a 100%);color:#fff;padding:90px 0 80px;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(800px 400px at -10% 110%,rgba(255,255,255,.08),transparent 60%);pointer-events:none}
.hero h1{color:#fff;font-size:clamp(34px,4.6vw,56px);font-weight:800}
.hero .lead{color:#cfd9ec;font-size:18px;max-width:580px;margin-top:14px}
.hero .label{background:rgba(245,183,49,.18);color:#ffd88c;border:1px solid rgba(245,183,49,.4)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;position:relative;z-index:1}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px;max-width:520px}
.hero-stats .stat{border-left:2px solid rgba(255,255,255,.18);padding-left:14px}
.hero-stats .stat b{display:block;color:#fff;font-size:22px;font-weight:800}
.hero-stats .stat span{color:#a9b6d0;font-size:12px;text-transform:uppercase;letter-spacing:.14em}
.hero-mock{position:relative;border-radius:3px;background:#091226;border:1px solid rgba(255,255,255,.08);box-shadow:0 60px 120px -40px rgba(0,0,0,.6);padding:24px}
.hero-mock svg{display:block;width:100%;height:auto}

/* Catalog */
.catalog-card{display:flex;flex-direction:column;gap:14px;text-decoration:none;color:inherit;height:100%;transition:transform .2s,box-shadow .2s,border-color .2s}
.catalog-card:hover{transform:translateY(-2px);border-color:var(--brand)}
.catalog-thumb{position:relative;aspect-ratio:5/3;border-radius:3px;background:linear-gradient(135deg,#0d2454,#1f3a73);display:grid;place-items:center;color:#fff;overflow:hidden;border:1px solid rgba(255,255,255,.06)}
.catalog-thumb::before{content:"";position:absolute;inset:0;background:radial-gradient(420px 200px at 80% -20%,rgba(245,183,49,.22),transparent 60%),radial-gradient(420px 200px at 0% 120%,rgba(255,255,255,.05),transparent 60%);pointer-events:none}
.catalog-thumb span{position:relative;font-family:'Inter',sans-serif;font-weight:800;font-size:clamp(18px,2.4vw,28px);letter-spacing:-.01em;text-align:center;padding:0 16px;text-shadow:0 0 18px rgba(245,183,49,.35);line-height:1.1}
.catalog-thumb .badge-edge{position:absolute;left:14px;top:14px;font-size:10px;letter-spacing:.18em;color:#ffd88c;text-transform:uppercase;font-weight:700}
.catalog-card h3{margin:0}
.catalog-card .arrow{margin-top:auto;color:var(--brand);font-weight:700;font-size:14px}

/* Sign editor */
.configurator-section{padding:24px 0 48px}
.split{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,410px);gap:18px;align-items:start}
.sticky{position:sticky;top:88px}
.canvas-wrap{background:radial-gradient(800px 400px at 50% -10%,rgba(255,255,255,.04),transparent 60%),linear-gradient(180deg,#08142b,#040a18);border:1px solid rgba(255,255,255,.06);border-radius:3px;padding:12px;overflow:hidden;box-shadow:inset 0 0 0 1px rgba(255,255,255,.02)}
.sign-svg{width:100%;height:clamp(260px,36vw,330px);display:block;touch-action:none}
.toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding-top:12px}
.toolbar label{display:inline-flex;align-items:center;gap:8px;margin:0;font-weight:600;font-size:13px;color:var(--muted)}
.config-sidebar{display:flex;flex-direction:column;gap:14px;position:relative;z-index:1;align-self:start}
.config-sidebar>.card{margin-top:0!important}
.price-card{z-index:6;overflow:hidden;align-self:stretch;isolation:isolate}
.price-box{position:relative;z-index:2;padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:14px;background:#fff}
.price-box .muted{font-size:12px;margin:4px 0 0}
.currency-actions{display:flex;gap:8px;margin-bottom:14px;position:relative;z-index:2}
.options-card{scroll-margin-top:110px}
.opt{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--line);border-radius:3px;padding:12px 14px;cursor:pointer;background:#fff;margin-top:8px;transition:all .15s}
.opt:first-child{margin-top:0}
.opt:hover{border-color:var(--brand)}
.opt.active{border-color:var(--brand);background:rgba(31,58,115,.05);box-shadow:inset 0 0 0 1px var(--brand)}
.opt b{font-size:14px;color:var(--ink)}
.opt small{color:var(--muted);font-weight:600}
.designer-card.p,.measure-card.p,.price-card.p{padding:18px}
.config-sidebar [data-options]{min-width:0}
.variant-panel{margin-top:0;background:#f8fbfd;border-color:#d8e5ef;box-shadow:0 18px 42px -36px rgba(42,107,107,.42);padding:12px}
.variant-grid{display:grid;grid-template-columns:1fr;gap:12px}
.variant-select-field{display:block;margin:0;color:#2f3a46;font-size:13px;font-weight:700}
.variant-select-field span{display:block;margin-bottom:6px}
.variant-select{height:44px;background:#fff;color:#182235;border-color:#d8e2ec}
.variant-select:focus{border-color:#42b4b4;box-shadow:0 0 0 3px rgba(66,180,180,.14)}
.variant-field-missing .variant-select{border-color:#d94b4b;box-shadow:0 0 0 3px rgba(217,75,75,.1)}
.variant-title{margin:0 0 10px;text-align:center;color:#42b4b4;font-size:13px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}
.variant-group{min-width:0}
.variant-group h3{margin:0 0 5px;padding:0;border-bottom:none;font-size:11px;color:#6b7280;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.variant-options{display:flex;flex-wrap:wrap;gap:5px}
.variant-toggle-group .variant-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:8px}
.variant-color-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px}
.variant-image-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px}
.variant-image-option.opt{align-items:center;min-height:58px}
.variant-image-thumb-wrap{position:relative;width:30px;height:30px;flex:0 0 30px;border-radius:3px;border:1px solid rgba(11,31,68,.18);background:#f6f8fc;display:grid;place-items:center;cursor:zoom-in}
.variant-image-thumb-wrap.empty{cursor:default}
.variant-image-thumb{width:100%;height:100%;object-fit:contain;display:block;border-radius:2px}
.variant-image-thumb-wrap.empty::before{content:"";width:14px;height:14px;border:1px dashed #cbd5e1;border-radius:2px}
.variant-image-popover{position:absolute;right:calc(100% + 12px);top:50%;transform:translateY(-50%);z-index:70;display:none;padding:10px;border:1px solid var(--line);border-radius:3px;background:#fff;box-shadow:0 18px 38px rgba(11,31,68,.18);pointer-events:none}
.variant-image-thumb-wrap:hover .variant-image-popover{display:block}
.variant-image-popover img{display:block;width:auto;height:auto;max-width:320px;max-height:240px;border-radius:3px;object-fit:contain}
.variant-image-popover b{display:block;margin-top:8px;font-size:13px;color:var(--ink);white-space:nowrap}
.variant-option.opt{position:relative;display:grid;grid-template-columns:14px minmax(0,1fr) max-content;align-items:center;min-width:0;width:100%;min-height:46px;margin-top:0;padding:8px 10px;gap:8px;justify-content:stretch;text-align:left;font-size:12px;border-radius:3px;border:1.5px solid #d1d5db;background:#fff;box-shadow:none;transition:all .15s ease}
.variant-option.opt.has-thumb{min-height:64px}
.variant-image-option.opt{grid-template-columns:14px 30px minmax(0,1fr) max-content}
.variant-color-option.opt{grid-template-columns:30px minmax(0,1fr) max-content}
.variant-color-option.opt{align-items:center;min-height:58px}
.variant-option.opt:hover{border-color:#42b4b4;background:#f0fafa}
.variant-option.opt.active{border-color:#42b4b4;background:#42b4b4;color:#fff;box-shadow:0 2px 8px rgba(66,180,180,.25)}
.variant-field-missing .variant-option.opt{border-color:#d94b4b}
.variant-swatch{width:30px;height:30px;flex:0 0 30px;border-radius:3px;border:1px solid rgba(11,31,68,.18);box-shadow:inset 0 0 0 1px rgba(255,255,255,.35)}
.variant-option .variant-radio{width:14px;height:14px;flex:0 0 14px;border:2px solid #cbd5e1;border-radius:50%;background:#fff;box-shadow:inset 0 0 0 3px #fff}
.variant-option.active .variant-radio{border-color:#fff;background:#1f3a73}
.variant-option .opt-row{display:flex;align-items:center;flex:1 1 auto;min-width:0;gap:8px}
.variant-option .opt-text{display:block;min-width:0}
.variant-option .opt-text b{display:block;font-size:12px;font-weight:600;color:inherit;line-height:1.25;overflow-wrap:break-word;word-break:normal}
.variant-option.active .opt-text b{color:#fff}
.variant-price{justify-self:end;align-self:center;min-width:62px;margin-left:0;color:#f18625;font-size:10px;font-weight:800;line-height:1.2;text-align:right;white-space:nowrap}
.variant-price.zero{display:none}
.variant-option.active .variant-price{color:rgba(255,255,255,.85)}
.variant-thumb{width:42px!important;height:42px!important;flex:0 0 42px;border-radius:3px}
@media(max-width:900px){.variant-grid{grid-template-columns:1fr}.variant-title{font-size:12px}.variant-toggle-group .variant-options,.variant-image-options,.variant-color-options{grid-template-columns:1fr}.variant-option .opt-text b{font-size:12px}.variant-price{font-size:10px}}
@media(max-width:420px){.variant-option.opt{grid-template-columns:14px minmax(0,1fr);align-items:start}.variant-image-option.opt{grid-template-columns:14px 30px minmax(0,1fr)}.variant-color-option.opt{grid-template-columns:30px minmax(0,1fr)}.variant-price{grid-column:2 / -1;justify-self:start;min-width:0;text-align:left}.variant-image-option .variant-price{grid-column:3 / -1}.variant-color-option .variant-price{grid-column:2 / -1}}

.price{font-size:28px;font-weight:800;letter-spacing:0;line-height:1.18;margin:6px 0 0;color:#f18625}
.price-sub{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.14em;font-weight:700}
.order-option-summary{margin-top:14px}
.order-option-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:8px;margin-top:8px;max-width:760px}
.order-option-row{display:grid;grid-template-columns:minmax(96px,.8fr) minmax(0,1fr);gap:10px;align-items:center;padding:9px 11px;border:1px solid var(--line);border-radius:3px;background:#f8fbfd;color:var(--ink);font-size:13px;line-height:1.25}
.order-option-row span{min-width:0;color:var(--muted);font-weight:700;overflow-wrap:anywhere}
.order-option-row b{min-width:0;color:var(--ink);font-weight:800;overflow-wrap:anywhere}

/* Notices */
.notice{padding:14px 16px;border-radius:3px;background:#eaf3ff;border:1px solid #c4dafd;color:#1c437b;font-size:14px}
.notice.danger{background:#fff1f1;border-color:#f5c4c4;color:var(--danger)}
.notice.ok{background:#e8f8ec;border-color:#bce5c8;color:var(--ok)}

/* Tables */
.table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:3px;overflow:hidden}
.table th,.table td{padding:14px 16px;text-align:left;font-size:14px}
.table th{background:var(--soft);color:var(--ink-2);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:11px}
.table tr+tr td{border-top:1px solid var(--line)}
.badge{display:inline-block;padding:4px 10px;border-radius:3px;font-size:11px;font-weight:700;background:var(--soft);color:var(--ink-2);text-transform:uppercase;letter-spacing:.06em}
.badge.pending{background:#fff4d6;color:#7a5a07}
.badge.paid{background:#e8f8ec;color:var(--ok)}
.badge.in_production{background:#dfe8fb;color:var(--brand)}
.badge.shipped{background:#e2f0fb;color:#0c5380}
.badge.delivered{background:#e8f8ec;color:var(--ok)}
.badge.cancelled{background:#ffe6e6;color:var(--danger)}

/* Footer */
.footer{background:var(--brand-deep);color:#c8d3eb;margin-top:48px}
.footer .container{padding-top:38px;padding-bottom:26px}
.footer h3,.footer b{color:#fff}
.footer a{color:#cfd9ec}
.footer a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:18px 0;font-size:12px;color:#90a0c4;display:flex;justify-content:space-between}

/* Admin shell */
.admin-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.admin-shell .sidebar{background:#0a1a3a;color:#cdd5e6;padding:26px 18px;display:flex;flex-direction:column;gap:6px;position:sticky;top:0;height:100vh;overflow:hidden}
.sidebar-brand{display:flex;align-items:center;gap:10px;color:#fff;font-weight:800;margin-bottom:18px}
.sidebar-brand .brand-mark{background:#fff;color:var(--brand-deep);box-shadow:none}
.sidebar-user{padding:12px;border-radius:3px;background:rgba(255,255,255,.05);font-size:13px;color:#dde4ee;margin-bottom:14px}
.sidebar-user b{display:block;color:#fff;font-size:14px}
.sidebar nav{min-height:0;overflow-y:auto}
.sidebar nav a{display:block;padding:10px 12px;border-radius:3px;color:#c0cae0;font-weight:600;font-size:14px;margin:2px 0}
.sidebar nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.sidebar nav a.active{background:#fff;color:var(--brand-deep)}
.sidebar-bottom{margin-top:auto;display:flex;flex-direction:column;gap:6px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08);flex-shrink:0}
.admin-main{padding:32px 36px;background:var(--bg);min-height:100vh}
.admin-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.admin-topbar h1{margin:0}
.stat-card{padding:20px}
.stat-card .stat-num{font-size:30px;font-weight:800;margin:8px 0 4px;color:var(--ink)}
.stat-card .stat-foot{color:var(--muted);font-size:13px}
.user-list{display:grid;gap:12px}
.user-card{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:start;padding:14px;border:1px solid var(--line);border-radius:3px;background:#fff}
.user-edit-form{display:grid;grid-template-columns:90px minmax(150px,1fr) minmax(190px,1.2fr) minmax(150px,1fr) 120px auto;gap:10px;align-items:end}
.user-edit-form label{margin:0}
.user-delete-form{margin:0;align-self:end}
@media(max-width:1200px){.user-card{grid-template-columns:1fr}.user-edit-form{grid-template-columns:1fr 1fr}.user-delete-form{justify-self:start}}
@media(max-width:640px){.user-edit-form{grid-template-columns:1fr}}

.pricing-compact-form{padding:22px}
.pricing-compact-form h3{margin-top:20px!important;font-size:15px}
.pricing-compact-form h4{font-size:14px;margin-bottom:10px}
.pricing-compact-form .pricing-module h3{padding:10px 12px;text-align:center;font-weight:800;line-height:1.25;text-transform:uppercase;background:#d9dee7;color:var(--ink);border-radius:3px}
.pricing-compact-form .pricing-module + .pricing-module h3{margin-top:26px!important}
.pricing-compact-form .table{width:100%;max-width:100%;margin-top:8px}
.pricing-compact-form .table th,.pricing-compact-form .table td{padding:7px 9px;font-size:12px;vertical-align:middle}
.pricing-compact-form .table th{font-size:10px;letter-spacing:.05em;line-height:1.25}
.pricing-compact-form .table .input{height:34px;padding:6px 9px;font-size:12px;line-height:1.2}
.pricing-compact-form .table td:nth-child(1) .input{max-width:118px}
.pricing-compact-form .table td:nth-child(2) .input{max-width:140px}
.pricing-compact-form .table td:nth-child(3) .input,
.pricing-compact-form .table td:nth-child(4) .input,
.pricing-compact-form .table td:nth-child(5) .input{max-width:118px}
.pricing-compact-form .pricing-currency-select{display:block;width:76px!important;min-width:76px;height:34px;padding:6px 7px;font-size:12px;line-height:1.2}
.pricing-compact-form .table input.input[type="text"],
.pricing-compact-form .table input.input:not([type]){width:108px;max-width:108px}
.pricing-compact-form .table label.flex{display:inline-flex;align-items:center;margin:0;font-size:12px}
.pricing-compact-form input[type="checkbox"]{width:15px;height:15px}
.pricing-compact-form .btn-ghost{padding:8px 12px;font-size:12px}
.pricing-compact-form .pricing-delete-row{padding:6px 10px;color:#b42318;border-color:#f4b8b2;background:#fff}
.pricing-compact-form .pricing-delete-row:hover{background:#fff1f0;color:#8c1d18}
.pricing-compact-form .grid-4{gap:8px!important}
.pricing-compact-form .card.p-sm{padding:12px}
.pricing-compact-form > .flex:last-of-type{margin-top:18px!important}
.pricing-compact-form .pricing-lighting-card{width:100%;max-width:100%;margin-top:8px!important;padding:10px!important;overflow:auto}
.pricing-compact-form .pricing-lighting-card h4{margin:0 0 8px;padding:10px 12px;font-size:13px;line-height:1.25;text-align:center;font-weight:800;background:#d9dee7;color:var(--ink);border-radius:3px}
.pricing-compact-form .pricing-lighting-grid{grid-template-columns:repeat(4,minmax(120px,1fr));gap:8px!important}
.pricing-compact-form .pricing-lighting-grid label{font-size:12px;margin-bottom:0}
.pricing-compact-form .pricing-lighting-grid .input{height:34px;padding:6px 9px;font-size:12px;line-height:1.2;margin-top:5px}
.pricing-compact-form .pricing-lighting-grid .pricing-currency-select{margin-top:5px}
.pricing-compact-form .pricing-lighting-card .table{margin-top:8px!important}
.pricing-compact-form .pricing-lighting-model-table td:nth-child(1) .input{max-width:110px}
.pricing-compact-form .pricing-lighting-model-table td:nth-child(2) .input{max-width:130px}
.pricing-compact-form .pricing-lighting-model-table td:nth-child(3) .input,
.pricing-compact-form .pricing-lighting-model-table td:nth-child(5) .input,
.pricing-compact-form .pricing-lighting-model-table td:nth-child(6) .input,
.pricing-compact-form .pricing-lighting-model-table td:nth-child(7) .input{max-width:104px}
@media(max-width:900px){.pricing-compact-form .table{width:100%}.pricing-compact-form .table .input{max-width:none!important}}

.category-group-head{display:flex;align-items:end;gap:12px;flex-wrap:wrap;margin:-8px -8px 14px;padding:14px;background:var(--brand);border:1px solid var(--brand-deep);border-radius:3px}
.category-group-head label{margin:0;font-weight:800;color:#fff}
.category-group-head .input,.category-group-head select{margin-top:7px;background:#fff}
.category-group-name{min-width:260px;flex:1 1 360px}
.category-group-type{min-width:180px;flex:0 1 250px}
.category-group-sort{width:100px;flex:0 0 100px}
.category-group-head .flex:last-of-type{margin-left:auto}
@media(max-width:900px){.category-group-head{align-items:stretch}.category-group-name,.category-group-type,.category-group-sort{width:auto;flex:1 1 100%}.category-group-head .flex:last-of-type{margin-left:0}}

/* Admin media preview */
.media-thumb-button{display:inline-flex;width:72px;height:52px;padding:0;border:1px solid var(--line);border-radius:3px;background:#fff;overflow:hidden;cursor:pointer}
.media-thumb-button:hover,.media-thumb-button:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(31,58,115,.12)}
.media-thumb-button img{width:100%;height:100%;object-fit:cover;display:block}
.media-modal{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;padding:28px}
.media-modal[hidden]{display:none}
.media-modal__backdrop{position:absolute;inset:0;background:rgba(10,26,58,.68);backdrop-filter:blur(3px)}
.media-modal__dialog{position:relative;width:min(920px,100%);max-height:calc(100vh - 56px);background:#fff;border:1px solid var(--line);border-radius:3px;box-shadow:0 40px 100px -36px rgba(0,0,0,.55);overflow:hidden;display:flex;flex-direction:column}
.media-modal__close{position:absolute;top:12px;right:12px;z-index:1;width:38px;height:38px;border:1px solid var(--line);border-radius:3px;background:#fff;color:var(--ink);font-size:24px;line-height:1;cursor:pointer;box-shadow:0 12px 28px -18px rgba(11,31,68,.5)}
.media-modal__close:hover,.media-modal__close:focus{outline:none;border-color:var(--brand);color:var(--brand)}
.media-modal__image-wrap{min-height:260px;max-height:70vh;background:#08142b;display:grid;place-items:center;padding:20px}
.media-modal__image-wrap img{max-width:100%;max-height:66vh;border-radius:3px;object-fit:contain;box-shadow:0 20px 60px -34px rgba(0,0,0,.7)}
.media-modal__footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px;border-top:1px solid var(--line);background:#fff}
.media-modal__footer h2{font-size:18px;margin:4px 0 0;word-break:break-word}
.media-modal-open{overflow:hidden}
@media(max-width:640px){.media-modal{padding:14px}.media-modal__footer{align-items:flex-start;flex-direction:column}.media-modal__footer .btn-primary{width:100%}}

/* Auth screen */
.auth-screen{min-height:100vh;display:grid;place-items:center;background:radial-gradient(800px 400px at 80% -10%,rgba(245,183,49,.16),transparent 60%),linear-gradient(135deg,#0a1a3a,#1f3a73);padding:40px 20px}
.auth-card{width:100%;max-width:420px;background:#fff;border-radius:3px;padding:32px;box-shadow:0 60px 120px -40px rgba(0,0,0,.5)}
.auth-card h1{font-size:24px;margin-bottom:6px}

/* Cart pieces */
.cart-row{display:flex;gap:16px;align-items:center;padding:16px;border:1px solid var(--line);border-radius:3px;background:#fff;margin-top:12px}
.cart-row .thumb{width:80px;height:60px;border-radius:3px;background:linear-gradient(135deg,#1f3a73,#0a1a3a);display:grid;place-items:center;color:#fff;font-weight:800;text-shadow:0 0 12px rgba(245,183,49,.4)}
.cart-row .info{flex:1}
.cart-row .info b{display:block;color:var(--ink)}
.cart-row .info span{color:var(--muted);font-size:13px}
.cart-variants{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.cart-variant{display:inline-flex;align-items:center;gap:6px;max-width:100%;padding:5px 8px;border:1px solid rgba(31,58,115,.14);border-radius:3px;background:#f8fbfd;color:var(--muted);line-height:1.2}
.cart-variant span{font-size:11px;text-transform:uppercase;letter-spacing:.04em}
.cart-variant b{display:inline!important;color:var(--ink)!important;font-size:12px;overflow-wrap:anywhere}
.cart-row .price-cell{text-align:right}
.cart-drawer-backdrop{position:fixed;inset:0;z-index:90;background:rgba(11,31,68,.22)}
.cart-drawer-trigger{position:fixed;right:18px;top:50%;z-index:88;transform:translateY(-50%);padding:10px 12px;border:1px solid var(--line);border-radius:3px;background:#fff;color:var(--ink);font-weight:800;box-shadow:0 18px 42px -26px rgba(11,31,68,.45);cursor:pointer}
.cart-drawer{position:fixed;top:0;right:0;z-index:100;width:min(980px,100vw);height:100vh;padding:22px;background:#fff;border-left:1px solid var(--line);box-shadow:-32px 0 70px -44px rgba(11,31,68,.55);transform:translateX(100%);transition:transform .22s ease;overflow:auto}
.cart-drawer.open{transform:translateX(0)}
.cart-drawer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.cart-drawer-head h3{margin:7px 0 0;font-size:22px;color:var(--ink)}
.cart-drawer-close{width:34px;height:34px;border:1px solid var(--line);border-radius:3px;background:#fff;color:var(--ink);font-size:24px;line-height:1;cursor:pointer}
.cart-drawer-empty{margin:16px 0 0}
.proforma-meta{display:flex;justify-content:space-between;gap:10px;margin:14px 0;color:var(--muted);font-size:12px;font-weight:700}
.proforma-table{border:1px solid var(--line);border-radius:3px;overflow:auto;background:#fff}
.proforma-row{display:grid;grid-template-columns:42px minmax(105px,.8fr) minmax(110px,.9fr) minmax(120px,.9fr) minmax(130px,1fr) minmax(120px,.9fr) minmax(130px,1fr) minmax(105px,.8fr);min-width:900px;align-items:stretch;border-top:1px solid var(--line);font-size:14px}
.proforma-row:first-child{border-top:0}
.proforma-row>span{min-width:0;padding:12px 10px;border-left:1px solid var(--line);display:flex;align-items:center;overflow-wrap:anywhere}
.proforma-row>span:first-child{border-left:0}
.proforma-row-head{background:#f8fbfd;color:var(--ink);font-size:13px;font-weight:800;text-transform:none;letter-spacing:0}
.proforma-row-head>span{align-items:center;color:var(--ink)}
.proforma-row b{display:block;color:var(--ink);font-size:14px;line-height:1.25}
.proforma-price-cell{flex-direction:column;align-items:flex-start!important;gap:6px}
.proforma-extra{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:6px;padding:8px 10px;border-top:1px solid var(--line);background:#fbfdff}
.proforma-extra span{display:inline-flex;gap:4px;padding:4px 7px;border:1px solid rgba(31,58,115,.14);border-radius:3px;background:#fff;color:var(--muted);font-size:11px;line-height:1.2}
.proforma-extra b{display:inline!important;font-size:11px!important;color:var(--ink)!important}
.cart-drawer-remove{padding:4px 7px;border:1px solid rgba(185,28,28,.24);border-radius:3px;background:#fff;color:var(--danger);font-size:11px;font-weight:800;cursor:pointer}
.proforma-summary{margin-top:14px;margin-left:auto;width:min(260px,100%)}
.proforma-summary>div{display:flex;justify-content:space-between;gap:12px;padding:8px 0;color:var(--muted);font-size:13px}
.proforma-summary b{color:var(--ink)}
.proforma-grand{border-top:1px solid var(--line);font-weight:800}
.proforma-grand b{color:#f18625;font-size:18px}
.proforma-checkout{width:100%;margin-top:16px}

/* Option editor grid */
.option-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(440px,1fr));gap:16px}
.option-card{display:grid;grid-template-columns:140px minmax(0,1fr);gap:16px;padding:16px;border:1px solid var(--line);border-radius:3px;background:#fff}
.option-thumb{display:flex;flex-direction:column;gap:8px;min-width:0}
.option-thumb img{width:140px;height:100px;object-fit:cover;border-radius:3px;border:1px solid var(--line);background:#f6f8fc}
.option-thumb-empty{width:140px;height:100px;border-radius:3px;border:1px dashed var(--line);display:grid;place-items:center;color:var(--muted);font-size:11px;background:#f6f8fc}
.thumb-upload{display:inline-flex;align-items:center;justify-content:center;padding:7px 10px;border-radius:3px;border:1px dashed var(--line);color:var(--brand);font-weight:600;font-size:12px;cursor:pointer;text-align:center;line-height:1.2}
.thumb-upload:hover{border-color:var(--brand);background:rgba(31,58,115,.05)}
.option-body{min-width:0;display:flex;flex-direction:column;gap:10px}
.option-body .input{width:100%}
.option-body label{margin:0;font-size:12px}
.option-color-field{display:flex;flex-direction:column;gap:6px}
.color-input-row{display:grid;grid-template-columns:46px minmax(0,1fr);gap:8px;align-items:center}
.color-input-row input[type=color]{width:46px;height:38px;padding:2px;border:1px solid var(--line);border-radius:3px;background:#fff}
.option-actions{display:flex;gap:8px;margin-top:auto;flex-wrap:wrap}
@media(max-width:560px){.option-card{grid-template-columns:1fr}.option-thumb{flex-direction:row;align-items:flex-start}.option-thumb img,.option-thumb-empty{width:120px;height:84px;flex-shrink:0}.thumb-upload{align-self:center}}

/* Production preview card */
.prod-card .label{margin-bottom:14px}
.prod-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.prod-item{display:flex;flex-direction:column;gap:4px;padding:12px 14px;background:#f6f8fc;border:1px solid var(--line);border-radius:3px;min-width:0}
.prod-key{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700}
.prod-val{font-size:15px;color:var(--ink);font-weight:700;word-break:break-word;line-height:1.35}
@media(max-width:760px){.prod-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:460px){.prod-grid{grid-template-columns:1fr}}

/* Customer-side option preview */
.opt{position:relative}
.opt .opt-thumb{width:38px;height:38px;border-radius:3px;object-fit:cover;border:1px solid var(--line);background:#f6f8fc}
.opt-row{display:flex;align-items:center;gap:12px}
.opt-text{flex:1;min-width:0}
.opt .preview{position:absolute;right:calc(100% + 12px);top:50%;transform:translateY(-50%);background:#fff;border:1px solid var(--line);border-radius:3px;padding:10px;box-shadow:0 18px 38px rgba(11,31,68,.18);width:220px;display:none;z-index:50;pointer-events:none}
.opt:hover .preview{display:block}
.opt .preview img{width:100%;height:150px;object-fit:cover;border-radius:3px;display:block}
.opt .preview b{display:block;margin-top:8px;font-size:13px;color:var(--ink)}
@media(max-width:1100px){.opt .preview{display:none !important}}

.variant-image-modal{position:fixed;inset:0;z-index:1100;display:grid;place-items:center;padding:24px}
.variant-image-modal[hidden]{display:none}
.variant-image-modal__backdrop{position:absolute;inset:0;background:rgba(10,26,58,.72);backdrop-filter:blur(3px)}
.variant-image-modal__dialog{position:relative;max-width:calc(100vw - 48px);max-height:calc(100vh - 48px);background:#fff;border:1px solid var(--line);border-radius:3px;box-shadow:0 40px 100px -36px rgba(0,0,0,.55);overflow:hidden;display:flex;flex-direction:column}
.variant-image-modal__close{position:absolute;top:10px;right:10px;z-index:1;width:36px;height:36px;border:1px solid var(--line);border-radius:3px;background:#fff;color:var(--ink);font-size:24px;line-height:1;cursor:pointer;box-shadow:0 12px 28px -18px rgba(11,31,68,.5)}
.variant-image-modal__close:hover,.variant-image-modal__close:focus{outline:none;border-color:var(--brand);color:var(--brand)}
.variant-image-modal__body{display:grid;place-items:center;max-height:calc(100vh - 112px);padding:18px;background:#f6f8fc}
.variant-image-modal__body img{display:block;width:auto;height:auto;max-width:calc(100vw - 84px);max-height:calc(100vh - 148px);object-fit:contain;border-radius:3px}
.variant-image-modal__footer{padding:12px 18px;border-top:1px solid var(--line);background:#fff;color:var(--ink);font-size:13px}
.variant-image-modal-open{overflow:hidden}
@media(max-width:640px){.variant-image-popover{display:none!important}.variant-image-modal{padding:14px}.variant-image-modal__dialog{max-width:calc(100vw - 28px);max-height:calc(100vh - 28px)}.variant-image-modal__body img{max-width:calc(100vw - 56px);max-height:calc(100vh - 136px)}}

/* Responsive */
@media(max-width:1000px){
  .hero-grid,.split,.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}
  .nav{display:none}
  .sticky,.price-card{position:static}
  .price{font-size:26px}
  .admin-shell{grid-template-columns:1fr}
  .admin-shell .sidebar{padding:18px;position:static;height:auto;overflow:visible}
  .sidebar nav{overflow:visible}
  .admin-main{padding:20px}
  .hero{padding:60px 0 50px}
}
@media(max-width:640px){
  .cart-drawer{padding:16px;width:100vw}
  .cart-drawer-trigger{right:12px;top:auto;bottom:16px;transform:none}
  .proforma-table{overflow:visible}
  .proforma-row{min-width:0;grid-template-columns:1fr;padding:10px}
  .proforma-row-head{display:none}
  .proforma-row>span{display:grid;grid-template-columns:112px minmax(0,1fr);gap:8px;border-left:0;border-top:1px solid var(--line);padding:8px 0}
  .proforma-row>span:first-child{border-top:0}
  .proforma-row>span::before{color:var(--muted);font-size:11px;font-weight:800;text-transform:uppercase}
  .proforma-row>span:nth-child(1)::before{content:"Sıra"}
  .proforma-row>span:nth-child(2)::before{content:"Ölçü"}
  .proforma-row>span:nth-child(3)::before{content:"Taraf"}
  .proforma-row>span:nth-child(4)::before{content:"Kasa Derinliği"}
  .proforma-row>span:nth-child(5)::before{content:"Ayak Seçimi"}
  .proforma-row>span:nth-child(6)::before{content:"Profil Rengi"}
  .proforma-row>span:nth-child(7)::before{content:"Mekan Seçimi"}
  .proforma-row>span:nth-child(8)::before{content:"Fiyat"}
  .proforma-price-cell{display:grid!important;align-items:start!important}
  .proforma-extra{grid-column:auto;margin-top:6px;border-top:1px solid var(--line);padding:8px 0 0}
}
@media(max-width:1120px){
  .store-hero-grid,.product-grid,.catalog-products.is-grid-view{grid-template-columns:repeat(2,minmax(0,1fr))}
  .category-nav a{min-width:155px}
}
@media(max-width:820px){
  .main-header-in{grid-template-columns:1fr;gap:12px;padding-top:14px;padding-bottom:14px}
  .site-actions{justify-content:space-between}
}
@media(max-width:720px){
  .container{padding:0 18px}
  .top-strip-in{align-items:flex-start;flex-direction:column;padding-top:10px;padding-bottom:10px}
  .top-contact,.top-links{gap:10px 14px}
  .site-actions{flex-wrap:wrap}
  .site-action-link{display:none}
  .site-actions .btn-primary,.site-actions .btn-ghost{flex:1}
  .site-search{height:48px}
  .category-scroll{padding:0}
  .category-nav{padding:12px 18px;gap:8px}
  .category-nav a{min-width:220px;padding:13px 16px}
  .store-hero{padding:48px 0 42px}
  .store-hero-grid,.product-grid,.catalog-products.is-grid-view{grid-template-columns:1fr}
  .catalog-products.is-list-view .store-product-card{grid-template-columns:1fr}
  .catalog-products.is-list-view .product-visual{min-height:220px}
  .store-hero .lead{font-size:16px}
  .hero-stats{grid-template-columns:1fr;gap:12px;margin-top:26px}
  .showcase-panel{padding:18px;border-radius:3px}
  .showcase-sign{min-height:245px;padding:34px 24px}
  .showcase-frame small{font-size:10px;letter-spacing:.14em}
  .store-section{padding:42px 0 52px}
  .store-section-head,.catalog-hero-in{align-items:flex-start;flex-direction:column}
  .product-info{min-height:auto}
  .product-foot strong{font-size:22px}
  .catalog-toolbar{align-items:stretch;flex-direction:column}
  .filter-group,.view-tools{width:100%}
  .filter-pill{flex:1;justify-content:center}
  .footer-bottom{gap:8px;flex-direction:column}
}
@media(max-width:460px){
  .site-brand .brand-mark{width:48px;height:48px}
  .site-brand{font-size:18px}
  .site-brand small{font-size:10px}
  .site-search input{font-size:14px;padding-left:16px}
  .product-visual{min-height:210px}
  .catalog-products .product-visual{min-height:220px}
  .filter-group{display:grid;grid-template-columns:1fr}
}
