/* ===== COMO FONT ===== */
@font-face{font-family:'Como';src:url('../assets/fonts/Como/Como-Bold.ttf') format('truetype');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Como';src:url('../assets/fonts/Como/Como-ExtraBold.ttf') format('truetype');font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:'Como';src:url('../assets/fonts/Como/Como-Heavy.ttf') format('truetype');font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:'Como';src:url('../assets/fonts/Como/Como.ttf') format('truetype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Como';src:url('../assets/fonts/Como/Como-Medium.ttf') format('truetype');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Como';src:url('../assets/fonts/Como/Como-Light.ttf') format('truetype');font-weight:300;font-style:normal;font-display:swap}

/* ===== LUCIDE ICONS ===== */
[data-lucide]{display:inline-block;vertical-align:middle;stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round}
.ic{width:16px;height:16px;stroke-width:1.75}
.ic-sm{width:14px;height:14px;stroke-width:1.75}
.ic-md{width:18px;height:18px;stroke-width:1.5}
.ic-lg{width:20px;height:20px;stroke-width:1.5}
.ic-xl{width:24px;height:24px;stroke-width:1.5}
.ic-2xl{width:32px;height:32px;stroke-width:1.25}
.ic-3xl{width:40px;height:40px;stroke-width:1.25}
.adm-nav .ic-md{color:var(--gr);transition:color .2s}
.adm-nav:hover .ic-md,.adm-nav.act .ic-md{color:var(--g)}
.nav-link .ic-sm{margin-right:5px}
.btn [data-lucide]{margin-right:4px}
/* ===== RESET & VARS ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#060606;--s1:#101010;--s2:#171717;--s3:#1e1e1e;
  --bd:#252525;--bd2:#303030;
  --g:#C9953A;--gl:#E0AA50;--gd:rgba(201,149,58,.10);--gb:rgba(201,149,58,.20);
  --t:#3BBFB5;--td:rgba(59,191,181,.10);
  --w:#F0EFE9;--gr:#7A7972;--grd:#2A2A28;
  --red:#CC4444;--grn:#4A9A5A;
}
[data-theme="light"]{
  --bg:#F5F4F0;--s1:#FFFFFF;--s2:#EEEDE8;--s3:#E4E3DD;
  --bd:#D4D3CD;--bd2:#BFBEB8;
  --g:#9A7A28;--gl:#86691F;--gd:rgba(154,122,40,.08);--gb:rgba(154,122,40,.18);
  --t:#24857E;--td:rgba(36,133,126,.08);
  --w:#1A1A18;--gr:#5A5954;--grd:#B8B7B1;
  --red:#CC4444;--grn:#3D8A4D;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--w);font-family:'Outfit',sans-serif;line-height:1.6;overflow-x:hidden}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--gb)}
img{display:block;max-width:100%}

/* ===== KEYFRAMES ===== */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideR{from{transform:translateX(110%)}to{transform:translateX(0)}}
@keyframes dropIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:.6}50%{opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* ===== NAV ===== */
nav{
  position:fixed;top:0;left:0;right:0;height:62px;
  background:rgba(6,6,6,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--bd);z-index:1000;
  display:flex;align-items:center;justify-content:space-between;padding:0 36px;gap:16px;
}
.nav-logo{cursor:pointer;user-select:none;flex-shrink:0}
.nav-logo img{height:38px;object-fit:contain;filter:brightness(1.1)}
.nav-links{display:flex;align-items:center;gap:24px}
.nav-link{
  background:none;border:none;color:var(--gr);
  font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2.5px;
  text-transform:uppercase;cursor:pointer;padding:0;transition:color .2s;position:relative;
}
.nav-link:hover,.nav-link.act{color:var(--w)}
.nav-link.act::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--g)}
.nav-promo{background:var(--g);color:var(--bg);font-family:'Space Mono',monospace;font-size:9px;font-weight:700;letter-spacing:1.5px;padding:5px 10px;border:none;border-radius:4px;cursor:pointer;animation:promoPulse 2s ease-in-out infinite;transition:filter .15s}
.nav-promo:hover{filter:brightness(1.15)}
@keyframes promoPulse{0%,100%{box-shadow:0 0 0 0 rgba(201,149,58,.4)}50%{box-shadow:0 0 8px 3px rgba(201,149,58,.2)}}
.cart-btn{
  position:relative;background:none;border:1px solid var(--bd2);
  color:var(--gr);padding:7px 16px;font-family:'Space Mono',monospace;
  font-size:10px;letter-spacing:1.5px;text-transform:uppercase;
  cursor:pointer;transition:all .2s;white-space:nowrap;
}
.cart-btn:hover{border-color:var(--g);color:var(--g)}
.cart-badge{
  position:absolute;top:-9px;right:-9px;background:var(--g);color:var(--bg);
  width:18px;height:18px;border-radius:50%;font-size:10px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
.ham{display:none;background:none;border:none;color:var(--w);font-size:20px;cursor:pointer;padding:4px}
.mob-menu{
  display:none;position:fixed;top:62px;left:0;right:0;
  background:var(--s1);border-bottom:1px solid var(--bd);
  padding:20px 24px;z-index:999;flex-direction:column;gap:14px;
}
.mob-menu.open{display:flex}
.mob-menu .nav-link{font-size:12px;padding:6px 0;border-bottom:1px solid var(--bd)}

/* ===== TOAST ===== */
.toast{
  position:fixed;top:74px;right:20px;z-index:2000;
  background:var(--s2);border:1px solid var(--bd);
  border-left:3px solid var(--g);padding:14px 18px;max-width:300px;
  animation:dropIn .25s ease;box-shadow:0 12px 40px rgba(0,0,0,.7);
}
.toast.vis{border-left-color:var(--t)}
.toast.ok{border-left-color:var(--grn)}
.toast-ttl{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--g);margin-bottom:4px}
.toast.vis .toast-ttl{color:var(--t)}
.toast.ok .toast-ttl{color:var(--grn)}
.toast-msg{font-size:13px;color:var(--w);line-height:1.4}
.hidden{display:none!important}

/* ===== CART DRAWER ===== */
.cart-drawer{
  position:fixed;top:0;right:0;width:380px;max-width:100vw;height:100vh;
  background:var(--s1);border-left:1px solid var(--bd);z-index:1500;
  animation:slideR .28s ease;display:flex;flex-direction:column;overflow:hidden;
}
.cart-head{padding:22px 24px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between}
.cart-body{flex:1;overflow-y:auto;padding:16px 24px}
.cart-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--bd);align-items:flex-start}
.cart-thumb{width:60px;height:60px;background:var(--s2);border:1px solid var(--bd);flex-shrink:0;overflow:hidden}
.cart-thumb img{width:100%;height:100%;object-fit:cover}
.cart-foot{padding:20px 24px;border-top:1px solid var(--bd)}
.cart-total{display:flex;justify-content:space-between;font-family:'Cormorant Garamond',serif;font-size:22px;margin-bottom:18px;align-items:baseline}
.ov-bg{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:1400;animation:fadeIn .2s ease}

/* ===== HERO ===== */
.hero{
  min-height:100vh;position:relative;display:flex;align-items:center;
  overflow:hidden;padding-top:62px;
}
.hero-bg{
  position:absolute;inset:0;
  background:var(--bg);overflow:hidden;
}
.hero-bg-video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:.55; /* default, overridden by JS */
}
.hero-bg-img{
  position:absolute;inset:0;
  background-image:url('https://irp.cdn-website.com/fefec139/dms3rep/multi/DuAxJbSeQ9OK4mgiKBXR_ParametricWallArt_BobaBaar_2.v2.0000000.jpg');
  background-size:cover;background-position:center;
  opacity:0;transition:opacity 1s ease; /* hidden when video loads, fallback if video fails */
}
.hero-bg-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,6,6,1) 0%,rgba(6,6,6,.5) 50%,rgba(6,6,6,.2) 100%)}
.hero-canvas{position:absolute;inset:0;opacity:.12;pointer-events:none}
.hero-content{
  position:relative;z-index:2;padding:0 48px 80px;
  max-width:1280px;margin:0 auto;width:100%;
  animation:fadeUp .9s ease .1s both;
}
.hero-eye{
  font-family:'Space Mono',monospace;font-size:10px;letter-spacing:4px;
  text-transform:uppercase;color:var(--g);margin-bottom:22px;
  display:flex;align-items:center;gap:14px;
}
.hero-eye::after{content:'';height:1px;background:linear-gradient(90deg,var(--g),transparent);width:120px;flex-shrink:0}
h1.hero-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(58px,10vw,140px);
  font-weight:300;line-height:.9;letter-spacing:-4px;
  margin-bottom:28px;
}
h1.hero-title em{color:var(--g);font-style:italic}
.hero-sub{font-size:clamp(14px,1.6vw,16px);color:var(--gr);max-width:460px;line-height:1.9;margin-bottom:36px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}
.hero-strip{
  position:absolute;bottom:0;left:0;right:0;z-index:3;
  display:flex;overflow:hidden;border-top:1px solid var(--bd);
  background:rgba(6,6,6,.8);backdrop-filter:blur(8px);
}
.hero-strip-item{
  flex:1;padding:16px 24px;border-right:1px solid var(--bd);text-align:center;
  min-width:120px;
}
.hero-strip-item:last-child{border-right:none}
.strip-num{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:300;color:var(--g);line-height:1}
.strip-lbl{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gr);margin-top:3px}

/* ===== SECTIONS ===== */
.sec{padding:90px 48px;max-width:1280px;margin:0 auto}
.sec-full{padding:90px 48px;width:100%}
.lbl{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--g);margin-bottom:12px}
.h2{font-family:'Cormorant Garamond',serif;font-size:clamp(30px,4vw,54px);font-weight:300;line-height:1.08}
.sub{color:var(--gr);font-size:15px;line-height:1.88;max-width:520px;margin-top:12px}
.divider{height:1px;background:var(--bd)}
.divider-g{height:1px;background:linear-gradient(90deg,transparent,var(--g) 40%,transparent)}
.rule{height:1px;background:var(--bd);margin:0}

/* ===== BUTTONS ===== */
.btn{
  font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2px;
  text-transform:uppercase;cursor:pointer;padding:13px 28px;transition:all .2s;border:none;
  display:inline-flex;align-items:center;gap:8px;
}
.btn-g{background:var(--g);color:var(--bg);font-weight:700}
.btn-g:hover{background:var(--gl)}
.btn-o{background:transparent;color:var(--g);border:1px solid var(--g)}
.btn-o:hover{background:var(--gd)}
.btn-ghost{background:transparent;color:var(--gr);border:1px solid var(--bd)}
.btn-ghost:hover{border-color:var(--gr);color:var(--w)}
.btn-sm{padding:8px 16px;font-size:9px}
.btn-t{background:var(--t);color:var(--bg);font-weight:700}
.btn-t:hover{opacity:.85}

/* ===== IMAGE CARDS ===== */
.img-card{background:var(--s2);overflow:hidden;border:1px solid var(--bd);position:relative}
.img-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.img-card:hover img{transform:scale(1.04)}
.img-skeleton{
  background:linear-gradient(90deg,var(--s2) 25%,var(--s3) 50%,var(--s2) 75%);
  background-size:200% 100%;animation:shimmer 1.5s infinite;
}

/* ===== FEATURED INSTALL SPLIT ===== */
.feat-grid{
  display:grid;grid-template-columns:1.1fr 1fr;
  background:var(--s1);border:1px solid var(--bd);overflow:hidden;margin-top:48px;
}
.feat-img{
  position:relative;min-height:500px;overflow:hidden;background:var(--s2);
}
.feat-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:var(--bg)}
.feat-img-thumb-row{
  position:absolute;bottom:0;left:0;right:0;
  display:flex;border-top:1px solid var(--bd);background:rgba(0,0,0,.3);
}
.feat-thumb{
  flex:1;aspect-ratio:16/9;overflow:hidden;cursor:pointer;
  border-right:1px solid var(--bd);opacity:.5;transition:opacity .2s;
}
.feat-thumb:last-child{border-right:none}
/* Portfolio preview strip */
@media(max-width:768px){.port-preview-section{display:none !important}}
.port-preview-strip{display:flex;gap:3px;overflow-x:auto}
.port-preview-card{
  flex:0 0 auto;width:180px;position:relative;overflow:hidden;cursor:pointer;
  border:2px solid transparent;transition:all .2s;background:var(--s2);
}
.port-preview-card:hover{border-color:var(--g)}
.port-preview-card.act{border-color:var(--g);box-shadow:0 0 0 2px var(--gb)}
.port-preview-card img{width:100%;aspect-ratio:1;object-fit:cover;display:block;transition:transform .3s}
.port-preview-card:hover img{transform:scale(1.04)}
.port-preview-card-info{
  position:absolute;bottom:0;left:0;right:0;padding:8px 10px;
  background:linear-gradient(transparent,rgba(0,0,0,.8));color:#fff;
}
.port-preview-card-title{font-size:11px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.port-preview-card-meta{font-size:9px;color:rgba(255,255,255,.6);font-family:'Space Mono',monospace}
@media(max-width:768px){.port-preview-card{width:140px}}

.feat-browse-hint{
  position:absolute;top:16px;right:16px;z-index:2;
  background:rgba(0,0,0,.65);backdrop-filter:blur(8px);
  color:var(--w);padding:6px 14px;
  font-family:'Space Mono',monospace;font-size:10px;letter-spacing:1px;
  display:flex;align-items:center;gap:7px;
  opacity:0;transition:opacity .25s;pointer-events:none;
}
.feat-img:hover .feat-browse-hint{opacity:1}
.feat-thumb.act{opacity:1}
.feat-thumb img{width:100%;height:100%;object-fit:cover}
.feat-info{padding:56px 48px;display:flex;flex-direction:column;justify-content:center}

/* ===== GALLERY GRID ===== */
.gal-grid{display:grid;gap:2px;background:var(--bd)}
.gal-3{grid-template-columns:1fr 1fr 1fr}
.gal-2{grid-template-columns:1fr 1fr}
.gal-item{
  background:var(--s1);position:relative;overflow:hidden;cursor:pointer;
}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease,filter .4s ease}
.gal-item:hover img{transform:scale(1.05);filter:brightness(.7)}
.gal-ov{
  position:absolute;inset:0;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:20px;background:linear-gradient(transparent 40%,rgba(0,0,0,.8));
  opacity:0;transition:opacity .3s;
}
.gal-item:hover .gal-ov{opacity:1}
.gal-item.tall{grid-row:span 2}
.gal-item.wide{grid-column:span 2}

/* ===== PORTFOLIO ===== */
.port-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px}
.filt{
  background:transparent;border:1px solid var(--bd);color:var(--gr);
  padding:7px 18px;font-family:'Space Mono',monospace;font-size:9px;
  letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:all .2s;
}
.filt:hover,.filt.act{border-color:var(--g);color:var(--g);background:var(--gd)}
.port-grid{
  display:grid;gap:2px;background:var(--bd);
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
}
.port-item{
  background:var(--s1);position:relative;overflow:hidden;cursor:pointer;aspect-ratio:1;
}
.port-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s,filter .3s}
.port-item:hover img{transform:scale(1.06);filter:brightness(.6)}
.port-ov{
  position:absolute;inset:0;opacity:0;transition:opacity .3s;
  background:rgba(0,0,0,.72);display:flex;flex-direction:column;
  align-items:center;justify-content:center;padding:24px;text-align:center;gap:8px;
}
.port-item:hover .port-ov{opacity:1}
.port-price{
  position:absolute;top:10px;right:10px;z-index:2;
  background:rgba(0,0,0,.75);backdrop-filter:blur(6px);
  color:var(--g);padding:5px 10px;
  font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.5px;
  display:flex;align-items:center;gap:5px;
}
.port-no-img{
  background:var(--s2);display:flex;align-items:center;justify-content:center;
  width:100%;height:100%;
}

/* ===== SHOP ===== */
.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}
.prod{background:var(--s1);border:1px solid var(--bd);overflow:hidden;transition:border-color .3s,transform .25s;cursor:pointer}
.prod:hover{border-color:var(--g);transform:translateY(-3px)}
.prod-img{aspect-ratio:1;background:var(--s2);overflow:hidden;position:relative}
.prod-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.prod:hover .prod-img img{transform:scale(1.04)}
.prod-info{padding:18px 20px}
.prod-name{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400;margin-bottom:5px}
.prod-price{color:var(--g);font-family:'Space Mono',monospace;font-size:14px;margin-bottom:10px}
.prod-desc{color:var(--gr);font-size:13px;line-height:1.65;margin-bottom:16px}

/* ===== TAGS ===== */
.tag{display:inline-block;padding:3px 10px;font-family:'Space Mono',monospace;font-size:9px;letter-spacing:1px;text-transform:uppercase;border-radius:2px}
.tag-g{background:var(--gd);color:var(--g);border:1px solid var(--gb)}
.tag-t{background:var(--td);color:var(--t)}
.tag-gr{background:rgba(122,121,114,.12);color:var(--gr)}
.tag-grn{background:rgba(74,154,90,.12);color:var(--grn)}
.tag-red{background:rgba(204,68,68,.12);color:var(--red)}

/* ===== FORMS ===== */
.form-group{margin-bottom:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.flabel{display:block;font-family:'Space Mono',monospace;font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gr);margin-bottom:6px}
.finput,.fsel,.ftarea{
  background:var(--s2);border:1px solid var(--bd);color:var(--w);
  padding:11px 14px;font-family:'Outfit',sans-serif;font-size:14px;
  width:100%;outline:none;transition:border-color .2s;
}
.finput:focus,.fsel:focus,.ftarea:focus{border-color:var(--g)}
.finput::placeholder,.ftarea::placeholder{color:var(--grd)}
.ftarea{resize:vertical;min-height:110px}
.fsel option{background:var(--s2)}

/* ===== CALENDAR ===== */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal-head{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:1px;color:var(--gr);text-align:center;padding:5px;text-transform:uppercase}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;transition:all .2s;border:1px solid transparent}
.cal-day:hover{background:var(--s2);border-color:var(--bd)}
.cal-day.sel{background:var(--g);color:var(--bg);font-weight:700}
.cal-day.today{border-color:var(--g);color:var(--g)}
.cal-day.dis{opacity:.22;cursor:default;pointer-events:none}
.cal-day.avail{position:relative}
.cal-day.avail::after{content:'';position:absolute;bottom:3px;width:4px;height:4px;border-radius:50%;background:var(--g)}

/* Session idle timeout */
.idle-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);z-index:10001;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease}
.idle-card{max-width:360px;width:100%;background:var(--bg);border:1px solid var(--bd);border-radius:12px;padding:32px;text-align:center;box-shadow:0 12px 48px rgba(0,0,0,.5);animation:slideUp .3s ease}
.idle-icon{width:52px;height:52px;border-radius:50%;background:var(--gd);border:2px solid var(--gb);display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.idle-title{font-weight:700;font-size:18px;margin-bottom:8px}
.idle-desc{font-size:13px;color:var(--gr);margin-bottom:20px;line-height:1.6}
.idle-circle-wrap{position:relative;width:100px;height:100px;margin:0 auto 24px}
.idle-number{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Space Mono',monospace;font-weight:800;font-size:28px;color:var(--g);transition:color .3s}
.idle-number.alert{color:var(--red);animation:idleFlash 1s step-start infinite}
@keyframes idleFlash{0%,100%{opacity:1}50%{opacity:.15}}

/* Promo popup */
.promo-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease}
.promo-card{max-width:400px;width:100%;background:var(--bg);border:1px solid var(--bd);border-radius:12px;padding:32px;text-align:center;box-shadow:0 12px 48px rgba(0,0,0,.5);animation:slideUp .3s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}
.time-slots{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:14px}
.tslot{padding:8px 4px;text-align:center;border:1px solid var(--bd);cursor:pointer;font-size:11px;font-family:'Space Mono',monospace;transition:all .2s}
.tslot:hover,.tslot.sel{border-color:var(--g);color:var(--g);background:var(--gd)}
.tslot.taken{opacity:.3;cursor:default;pointer-events:none;text-decoration:line-through}

/* ===== TOGGLES ===== */
.trow{display:flex;align-items:center;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--bd)}
.tog-wrap{width:44px;height:24px;background:var(--bd2);border-radius:12px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}
.tog-wrap.on{background:var(--g)}
.tog-wrap::after{content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s}
.tog-wrap.on::after{transform:translateX(20px)}

/* ===== ADMIN ===== */
.admin-wrap{display:flex;min-height:calc(100vh - 62px)}
.adm-side{width:210px;background:var(--s1);border-right:1px solid var(--bd);padding-top:16px;flex-shrink:0;position:sticky;top:62px;height:calc(100vh - 62px);overflow-y:auto;display:flex;flex-direction:column}
.adm-nav{padding:11px 18px;cursor:pointer;font-size:13px;color:var(--gr);display:flex;align-items:center;gap:10px;transition:all .2s;border-left:2px solid transparent}
.adm-nav:hover{color:var(--w);background:var(--s2)}
.adm-nav.act{color:var(--g);border-left-color:var(--g);background:var(--gd)}
.adm-content{flex:1;padding:36px 40px;overflow-y:auto;max-height:calc(100vh - 62px)}
.ctable{width:100%;border-collapse:collapse}
.ctable th{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gr);padding:9px 12px;border-bottom:1px solid var(--bd);text-align:left}
.ctable td{padding:11px 12px;border-bottom:1px solid var(--bd);font-size:13px;vertical-align:middle}
.ctable tr:hover td{background:var(--s2)}
.upload-zone{border:2px dashed var(--bd);padding:44px;text-align:center;cursor:pointer;transition:all .2s;background:var(--s1)}
.upload-zone:hover,.upload-zone.drag{border-color:var(--g);background:var(--gd)}
.ig-preview{background:var(--s2);border:1px solid var(--bd);border-radius:8px;overflow:hidden;max-width:360px}
.ig-head{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--bd)}
.ig-av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--g),var(--t));flex-shrink:0}
.ig-photo{aspect-ratio:1;background:var(--s3);overflow:hidden}
.ig-photo img{width:100%;height:100%;object-fit:cover}
.spin{width:16px;height:16px;border:2px solid var(--bd);border-top-color:var(--g);border-radius:50%;animation:spin .6s linear infinite;display:inline-block}

/* ===== LIGHTBOX ===== */
.lb-bg{position:fixed;inset:0;background:rgba(0,0,0,.94);z-index:3000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease}
.lb-box{max-width:900px;width:100%;position:relative}
.lb-close{position:absolute;top:-40px;right:0;background:none;border:none;color:var(--gr);font-size:12px;cursor:pointer;font-family:'Space Mono',monospace;letter-spacing:2px;text-transform:uppercase;padding:4px 8px}

/* ===== VISIT BADGE ===== */
.visit-badge{display:inline-flex;align-items:center;gap:10px;padding:12px 18px;background:var(--gd);border:1px solid var(--gb);margin-top:16px}

/* ===== STATS BAND ===== */
.stats-band{background:var(--s1);border-top:1px solid var(--bd);border-bottom:1px solid var(--bd)}
.stats-inner{max-width:1280px;margin:0 auto;padding:0 48px;display:grid;grid-template-columns:repeat(4,1fr);border-left:1px solid var(--bd)}
.stat-cell{padding:44px 32px;border-right:1px solid var(--bd)}
.stat-num{font-family:'Cormorant Garamond',serif;font-size:52px;font-weight:300;color:var(--g);line-height:1}
.stat-lbl{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gr);margin-top:6px}

/* ===== FOOTER ===== */
footer{background:var(--s1);border-top:1px solid var(--bd);padding:56px 48px 32px}
.foot-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
.foot-link{color:var(--gr);font-size:13px;cursor:pointer;transition:color .2s;display:block;margin-bottom:10px}
.foot-link:hover{color:var(--w)}
.foot-col-ttl{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--g);margin-bottom:16px}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .feat-grid{grid-template-columns:1fr}
  .gal-3{grid-template-columns:1fr 1fr}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  nav{padding:0 14px;height:56px}
  .nav-logo span{display:none}
  .nav-links{display:none}
  .ham{display:block}
  .sec,.sec-full{padding:40px 16px}
  .hero-content{padding:0 16px 120px}
  .hero-sub{font-size:15px;line-height:1.7;max-width:100%}
  .hero-eye{font-size:9px;letter-spacing:2px;gap:8px}
  .hero-eye::after{width:60px}
  .hero-ctas .btn{padding:12px 20px;font-size:11px}
  .hero-strip{flex-wrap:wrap}
  .hero-strip-item{min-width:50%;border-bottom:1px solid var(--bd);padding:16px 14px}
  .hero-strip-item div:first-child{font-size:24px}
  .form-row{grid-template-columns:1fr}
  .cart-drawer{width:100%}
  .gal-3{grid-template-columns:1fr 1fr}
  .gal-item img{filter:brightness(.75)}
  .gal-ov{opacity:1 !important;background:linear-gradient(transparent 20%,rgba(0,0,0,.85)) !important;padding:14px !important}
  .gal-ov .tag{font-size:8px}
  .gal-ov div[style*="18px"]{font-size:15px !important;line-height:1.3 !important}
  .gal-ov div[style*="12px"]{font-size:11px !important}
  .adm-side{display:none}
  .feat-grid{gap:0}
  .feat-info{padding:24px 16px}
  .feat-info .h2{font-size:28px !important;margin-bottom:8px !important}
  .feat-info p{font-size:13px !important;line-height:1.7 !important}
  #featSpecsGrid{grid-template-columns:1fr !important;gap:8px !important}
  #featDimsSummary{font-size:13px !important}
  .visit-badge{padding:12px !important;font-size:12px !important}
  .lbl{font-size:9px;letter-spacing:3px}
  .h2{font-size:28px}
  .time-slots{grid-template-columns:repeat(3,1fr)}
  .stats-inner{grid-template-columns:1fr 1fr;padding:0 16px}
  .port-grid{grid-template-columns:1fr 1fr}
  .port-item img{filter:brightness(.7)}
  .port-ov{opacity:1 !important;background:linear-gradient(transparent 20%,rgba(0,0,0,.85)) !important;justify-content:flex-end !important;align-items:flex-start !important;text-align:left !important;padding:14px !important}
  .port-ov div[style*="18px"]{font-size:15px !important;line-height:1.3 !important}
  footer{padding:36px 16px 20px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:20px}
  .foot-col-ttl{font-size:9px}
  .foot-link{font-size:12px}
  .btn{padding:10px 18px;font-size:10px}
  .btn-sm{padding:6px 12px;font-size:9px}
  .tag{font-size:7px;padding:3px 8px}
}
@media(max-width:480px){
  h1.hero-title{font-size:42px;letter-spacing:-1px}
  .hero-content{padding:0 14px 100px}
  .hero-sub{font-size:14px}
  .gal-3{grid-template-columns:1fr}
  .port-grid{grid-template-columns:1fr}
  .shop-grid{grid-template-columns:1fr}
  .time-slots{grid-template-columns:repeat(2,1fr)}
  .stats-inner{grid-template-columns:1fr 1fr}
  .stat-num{font-size:38px}
  .foot-grid{grid-template-columns:1fr}
  .disc-tab i{display:none}
  .feat-info .h2{font-size:24px !important}
  .btn{font-size:9px}
}

/* ===== LUCIDE ICONS ===== */
[data-lucide]{
  display:inline-flex;flex-shrink:0;
  stroke:currentColor;fill:none;
  stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;
  vertical-align:middle;
}
.ic{width:16px;height:16px}
.ic-sm{width:13px;height:13px}
.ic-md{width:18px;height:18px}
.ic-lg{width:22px;height:22px}
.ic-xl{width:32px;height:32px}
.ic-hero{width:40px;height:40px}
/* icon + text alignment helpers */
.with-icon{display:inline-flex;align-items:center;gap:7px}
.adm-nav [data-lucide]{width:15px;height:15px;opacity:.7}
.adm-nav.act [data-lucide]{opacity:1}
.btn [data-lucide]{width:13px;height:13px}
/* ===== DISCIPLINE TABS ===== */
.disc-bar{
  position:sticky;top:62px;z-index:900;
  background:rgba(6,6,6,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--bd);
}
.disc-tabs{
  max-width:1280px;margin:0 auto;padding:0 48px;
  display:flex;gap:0;overflow-x:auto;
}
.disc-tab{
  background:none;border:none;border-bottom:2px solid transparent;
  color:var(--gr);padding:16px 28px;
  font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2px;text-transform:uppercase;
  cursor:pointer;transition:color .2s,border-color .2s;
  display:flex;align-items:center;gap:8px;white-space:nowrap;flex-shrink:0;
}
.disc-tab:hover{color:var(--w)}
.disc-tab.act{color:var(--g);border-bottom-color:var(--g)}
.disc-panel{animation:fadeUp .35s ease both}
@media(max-width:768px){
  .disc-tabs{padding:0 16px}
  .disc-tab{padding:14px 16px;font-size:9px;letter-spacing:1.5px;gap:6px}
}
@media(max-width:480px){
  .disc-tab{padding:12px 12px}
}

.ham [data-lucide]{width:20px;height:20px}
.lb-close [data-lucide]{width:14px;height:14px}
.cart-btn [data-lucide]{width:14px;height:14px}

/* ===== AUTH GATE ===== */
.auth-gate{
  min-height:calc(100vh - 62px);
  display:flex;align-items:center;justify-content:center;
  background:var(--bg);
}
.auth-card{
  background:var(--s1);border:1px solid var(--bd);
  padding:48px 40px;max-width:420px;width:100%;
  animation:fadeUp .4s ease both;
}
.auth-card [data-lucide]{display:block;margin:0 auto}

/* ===== ADMIN EMAIL LIST ===== */
#adminEmailsList .btn-ghost{padding:4px 8px}

/* ===== CONTENT LIBRARY — SPLIT PANE ===== */
.cl-wrap{display:flex;height:calc(100vh - 62px - 72px);border:1px solid var(--bd);background:var(--s1);overflow:hidden}
.cl-tree{width:300px;flex-shrink:0;border-right:1px solid var(--bd);display:flex;flex-direction:column;background:var(--bg)}
.cl-tree-head{padding:14px 16px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between}
.cl-tree-toggle{background:none;border:none;color:var(--gr);cursor:pointer;padding:2px;display:flex;align-items:center;transition:color .15s}
.cl-tree-toggle:hover{color:var(--g)}
.cl-search{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--bd);background:var(--s1)}
.cl-search-input{background:none;border:none;color:var(--w);font-size:13px;font-family:'Outfit',sans-serif;outline:none;width:100%}
.cl-search-input::placeholder{color:var(--grd)}
.cl-search-clear{background:none;border:none;color:var(--gr);cursor:pointer;padding:2px;display:flex;align-items:center;flex-shrink:0;transition:color .15s}
.cl-search-clear:hover{color:var(--w)}
.cl-tree-body{flex:1;overflow-y:auto;padding:6px 0}

/* Directory categories */
.cl-cat{user-select:none}
.cl-cat-head{
  display:flex;align-items:center;gap:8px;
  padding:8px 14px;cursor:pointer;font-family:'Space Mono',monospace;
  font-size:9px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--gr);transition:all .15s;
}
.cl-cat-head:hover{background:var(--s2);color:var(--w)}
.cl-cat-head [data-lucide]{width:12px;height:12px;transition:transform .15s}
.cl-cat-head.open [data-lucide]{transform:rotate(90deg)}
.cl-cat-count{margin-left:auto;font-size:9px;color:var(--grd);font-family:'Space Mono',monospace}
.cl-cat-items{display:none;padding-left:0}
.cl-cat.open .cl-cat-items{display:block}

/* Project items */
.cl-item{
  display:flex;align-items:center;gap:10px;
  padding:7px 14px 7px 32px;cursor:pointer;transition:all .15s;
  border-left:2px solid transparent;
}
.cl-item:hover{background:var(--s2)}
.cl-item.act{background:var(--gd);border-left-color:var(--g)}
.cl-item-thumb{width:32px;height:32px;flex-shrink:0;overflow:hidden;background:var(--s2);border:1px solid var(--bd)}
.cl-item-thumb img{width:100%;height:100%;object-fit:cover}
.cl-item-info{min-width:0;flex:1}
.cl-item-title{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cl-item-meta{font-size:10px;color:var(--gr);display:flex;gap:6px;align-items:center}
.cl-item-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.cl-item-dot.ok{background:var(--grn)}
.cl-item-dot.off{background:var(--grd)}
.cl-item-dot.needs{background:var(--grd)}
.cl-item-hidden{opacity:.5}
.cl-item-hidden .cl-item-thumb img{filter:grayscale(1)}

/* Tree drag handle & drag states */
.cl-drag-handle{display:flex;align-items:center;color:var(--grd);cursor:grab;opacity:0;transition:opacity .15s;flex-shrink:0}
.cl-item:hover .cl-drag-handle{opacity:1}
.cl-drag-handle:hover{color:var(--g)}
.cl-cat-drag{display:inline-flex;align-items:center;color:var(--grd);cursor:grab;opacity:0;transition:opacity .15s;margin-right:2px}
.cl-cat-head:hover .cl-cat-drag{opacity:1}
.cl-cat-drag:hover{color:var(--g)}
.cl-cat-add{display:inline-flex;align-items:center;justify-content:center;margin-left:auto;color:var(--grd);cursor:pointer;opacity:0;transition:opacity .15s;padding:2px 4px;border-radius:3px}
.cl-cat-head:hover .cl-cat-add{opacity:1}
.cl-cat-add:hover{color:var(--g);background:var(--gd)}
.cl-item-dragging{opacity:.3;background:var(--s2)}
.cl-cat.cl-item-dragging{opacity:.3}
.cl-drag-over-above{border-top:2px solid var(--g) !important}
.cl-drag-over-below{border-bottom:2px solid var(--g) !important}
.cl-drag-over-nest{background:var(--gd) !important;outline:2px solid var(--g);outline-offset:-2px;border-radius:4px}

/* Discipline tab admin */
.disc-admin-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--bd);margin-bottom:-1px;background:var(--s1);transition:all .15s}
.disc-admin-row:first-child{border-radius:6px 6px 0 0}
.disc-admin-row:last-child{border-radius:0 0 6px 6px}
.disc-admin-drag{display:flex;align-items:center;color:var(--grd);cursor:grab}
.disc-admin-drag:hover{color:var(--g)}
.disc-admin-dragging{opacity:.3}
.tog-sm{transform:scale(.8);transform-origin:right center}

/* Conversion progress panel */
.conversion-panel{position:fixed;bottom:20px;right:20px;width:320px;background:var(--s1);border:1px solid var(--bd);border-radius:8px;box-shadow:0 8px 32px rgba(0,0,0,.4);z-index:9999;padding:14px;max-height:60vh;overflow-y:auto}
.conv-panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--bd)}
.conv-panel-item{padding:8px 0;border-bottom:1px solid var(--bd)}
.conv-panel-item:last-child{border-bottom:none}

/* Admin tabs (shared) */
.adm-tab{background:none;border:none;color:var(--gr);font-family:'Space Mono',monospace;font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:10px 18px;cursor:pointer;border-bottom:2px solid transparent;display:flex;align-items:center;gap:6px;transition:all .15s}
.adm-tab:hover{color:var(--t)}
.adm-tab.act{color:var(--g);border-bottom-color:var(--g)}

/* Coupon cards */
.coupon-card{background:var(--s1);border:1px solid var(--bd);border-radius:8px;padding:16px;display:flex;gap:16px;align-items:center;margin-bottom:10px;transition:all .15s}
.coupon-card:hover{border-color:var(--g)}
.coupon-code{font-family:'Space Mono',monospace;font-size:16px;color:var(--g);letter-spacing:2px;min-width:140px}
.coupon-meta{flex:1;font-size:12px;color:var(--gr);line-height:1.8}
.coupon-badge{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:4px;display:inline-block}
.coupon-badge.pct{background:rgba(201,149,58,.15);color:var(--g);border:1px solid rgba(201,149,58,.3)}
.coupon-badge.fixed{background:rgba(59,191,181,.15);color:var(--t);border:1px solid rgba(59,191,181,.3)}
.coupon-badge.qr{background:rgba(155,89,182,.15);color:#B080D0;border:1px solid rgba(155,89,182,.3)}
.coupon-badge.expired{background:rgba(228,68,68,.1);color:var(--red);border:1px solid rgba(228,68,68,.2)}
.coupon-badge.used{background:rgba(76,175,80,.1);color:var(--grn);border:1px solid rgba(76,175,80,.2)}
.coupon-actions{display:flex;gap:6px;flex-shrink:0}

/* Settings tabs */
.settings-tabs{display:flex;gap:0;border-bottom:1px solid var(--bd);margin-bottom:24px}
.settings-tab{background:none;border:none;color:var(--gr);font-family:'Space Mono',monospace;font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:10px 18px;cursor:pointer;border-bottom:2px solid transparent;display:flex;align-items:center;gap:6px;transition:all .15s}
.settings-tab:hover{color:var(--t)}
.settings-tab.act{color:var(--g);border-bottom-color:var(--g)}
.settings-panel.hidden{display:none}

/* ===== SETTINGS SLIDER ===== */
.settings-slider{-webkit-appearance:none;width:100%;height:4px;background:var(--bd);outline:none;border-radius:2px}
.settings-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--g);border-radius:50%;cursor:pointer}
.settings-slider::-moz-range-thumb{width:16px;height:16px;background:var(--g);border-radius:50%;cursor:pointer;border:none}

/* ===== ADDRESS AUTOCOMPLETE ===== */
.addr-suggestions{
  position:absolute;top:100%;left:0;right:0;z-index:10;
  background:var(--s1);border:1px solid var(--bd);max-height:200px;overflow-y:auto;
}
.addr-sug-item{
  padding:10px 14px;font-size:12px;cursor:pointer;border-bottom:1px solid var(--bd);
  transition:background .1s;line-height:1.4;
}
.addr-sug-item:last-child{border-bottom:none}
.addr-sug-item:hover{background:var(--s2);color:var(--g)}

/* ===== DIMENSION INPUTS ===== */
.dim-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:8px}
.dim-depth{grid-column:1 / -1}
.dim-field{min-width:55px}
.dim-col{}
.dim-label{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:1px;color:var(--gr);margin-bottom:4px;text-transform:uppercase}
.dim-inputs{display:flex;gap:4px}
.dim-field{position:relative;flex:1}
.dim-input{padding:8px 24px 8px 6px!important;text-align:right;font-family:'Space Mono',monospace;font-size:12px;min-width:0}
.dim-input::-webkit-inner-spin-button{opacity:0}
.dim-unit{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-family:'Space Mono',monospace;font-size:10px;color:var(--gr);pointer-events:none}
.dim-preview{
  padding:10px 14px;background:var(--gd);border:1px solid var(--gb);
  font-family:'Space Mono',monospace;font-size:11px;color:var(--g);line-height:1.6;
}
@media(max-width:768px){.dim-grid{grid-template-columns:1fr 1fr}}

/* ===== INSTAGRAM COMPONENTS ===== */
.ig-saved-caption{padding:12px;border:1px solid var(--bd);margin-bottom:6px;background:var(--s2)}
.ig-saved-caption-text{font-size:12px;color:var(--gr);line-height:1.5;margin-bottom:6px;white-space:pre-wrap}
.ig-saved-caption-meta{display:flex;gap:8px;align-items:center;margin-bottom:6px}
.ig-saved-caption-actions{display:flex;gap:6px}
.ig-history-card{border:1px solid var(--bd);margin-bottom:8px;overflow:hidden}
.ig-history-head{padding:14px 18px;background:var(--s2);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--bd)}
.ig-history-caption{padding:14px 18px;font-size:13px;line-height:1.6;white-space:pre-wrap;max-height:120px;overflow-y:auto}
.ig-history-tags{padding:0 18px 10px;font-size:11px;color:var(--t)}
.ig-history-actions{padding:10px 18px;border-top:1px solid var(--bd);display:flex;gap:8px;background:var(--s2)}

/* ===== CMS EDITOR ===== */
.cms-section{margin-bottom:28px;border:1px solid var(--bd);overflow:hidden}
.cms-section-head{
  padding:12px 18px;background:var(--s2);
  font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:var(--g);border-bottom:1px solid var(--bd);
}
.cms-field{padding:14px 18px;border-bottom:1px solid var(--bd)}
.cms-field:last-child{border-bottom:none}
.cms-field .flabel span{font-size:9px}

/* ===== TAG PILLS ===== */
.tag-pills{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px;min-height:24px}
.tag-pill{
  display:inline-flex;align-items:center;gap:4px;
  background:var(--gd);border:1px solid var(--gb);color:var(--g);
  padding:3px 8px;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.5px;
}
.tag-pill button{background:none;border:none;color:var(--gr);cursor:pointer;font-size:13px;padding:0 0 0 2px;line-height:1}
.tag-pill button:hover{color:var(--red)}
.tag-suggestions{
  position:absolute;top:100%;left:0;right:0;z-index:10;
  background:var(--s1);border:1px solid var(--bd);max-height:200px;overflow-y:auto;
}
.tag-sug-item{
  padding:8px 12px;font-size:12px;cursor:pointer;display:flex;align-items:center;gap:6px;
  transition:background .1s;
}
.tag-sug-item:hover{background:var(--s2);color:var(--g)}
.tag-pool{margin-top:8px;display:flex;flex-wrap:wrap;gap:4px}
.tag-pool-pill{
  display:inline-block;padding:2px 8px;font-size:9px;font-family:'Space Mono',monospace;
  letter-spacing:.5px;color:var(--gr);border:1px solid var(--bd);cursor:pointer;transition:all .15s;
}
.tag-pool-pill:hover{border-color:var(--g);color:var(--g);background:var(--gd)}

/* Media tabs */
.media-tabs{display:flex;border-bottom:1px solid var(--bd);margin-bottom:12px}
.media-tab{
  background:none;border:none;border-bottom:2px solid transparent;
  color:var(--gr);padding:10px 18px;cursor:pointer;
  font-family:'Space Mono',monospace;font-size:10px;letter-spacing:1px;text-transform:uppercase;
  display:flex;align-items:center;gap:6px;transition:all .15s;
}
.media-tab:hover{color:var(--w)}
.media-tab.act{color:var(--g);border-bottom-color:var(--g)}
.media-tab-panel{min-height:100px}

/* Media cards in editor */
.media-card{border:1px solid var(--bd);position:relative;background:var(--s2);transition:transform .15s,opacity .15s;overflow:hidden}
.media-video-card{overflow:hidden}
.media-card[draggable]{cursor:grab}
.media-card.media-dragging{opacity:.3;transform:scale(.95)}
.media-card.media-drag-over{border-color:var(--g);box-shadow:0 0 0 2px var(--gb)}
.media-drag-handle{position:absolute;top:4px;right:4px;z-index:2;background:rgba(0,0,0,.6);color:var(--gr);padding:3px;display:flex;align-items:center;justify-content:center;cursor:grab;opacity:0;transition:opacity .15s}
.media-card:hover .media-drag-handle{opacity:1}
.media-drag-handle:hover{color:var(--w)}
.media-order-badge{position:absolute;bottom:4px;right:4px;background:rgba(0,0,0,.7);color:var(--gr);font-family:'Space Mono',monospace;font-size:9px;padding:1px 5px;pointer-events:none}
.media-card.media-poster{border-color:var(--g);box-shadow:0 0 0 1px var(--g)}
.media-card.media-hidden{opacity:.45}
.media-card.media-hidden img{filter:grayscale(1)}
.media-hidden-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;color:var(--gr)}
.media-play-overlay{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.35);color:rgba(255,255,255,.8);transition:background .2s;
}
.media-video-card:hover .media-play-overlay{background:rgba(0,0,0,.5);color:#fff}
.lb-play-overlay{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.5);color:var(--g);transition:all .2s;cursor:pointer;
}
.lb-play-overlay:hover{background:rgba(0,0,0,.6);color:var(--gl)}
/* convert btn moved into media-card-actions */
.media-vid-badge{position:absolute;bottom:4px;left:4px;background:rgba(0,0,0,.7);color:var(--w);padding:3px 6px;display:flex;align-items:center;border-radius:2px}
.media-poster-badge{position:absolute;top:4px;left:4px;background:var(--g);color:var(--bg);font-family:'Space Mono',monospace;font-size:8px;letter-spacing:.5px;padding:2px 6px;display:flex;align-items:center;gap:3px}
.media-card-actions{display:flex;border-top:1px solid var(--bd)}
.media-action{flex:1;background:none;border:none;border-right:1px solid var(--bd);color:var(--gr);padding:5px 0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}
.media-action:last-child{border-right:none}
.media-action:hover{background:var(--s3);color:var(--w)}
.media-action.on{color:var(--grn)}
.media-action.poster-active{color:var(--g)}

.cl-expand{display:flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0;cursor:pointer;color:var(--gr);margin-left:-18px;margin-right:2px}
.cl-expand:hover{color:var(--g)}
.cl-children{border-left:1px solid var(--bd);margin-left:41px}

/* Detail/editor pane */
.cl-detail{flex:1;overflow-y:auto;background:var(--s1)}
.cl-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:40px}

/* Editor inside detail */
.cl-ed-head{padding:20px 28px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:16px}
.cl-ed-head-thumb{width:56px;height:56px;flex-shrink:0;overflow:hidden;background:var(--s2);border:1px solid var(--bd)}
.cl-ed-head-thumb img{width:100%;height:100%;object-fit:cover}
.cl-ed-body{display:grid;grid-template-columns:1fr 1fr;gap:0;height:calc(100% - 97px)}
.cl-ed-form{padding:24px 28px;overflow-y:auto;border-right:1px solid var(--bd)}
.cl-ed-media{padding:24px 28px;overflow-y:auto}

@media(max-width:1024px){
  .cl-wrap{flex-direction:column;height:auto}
  .cl-tree{width:100%;max-height:300px;border-right:none;border-bottom:1px solid var(--bd)}
  .cl-ed-body{grid-template-columns:1fr}
  .cl-ed-form{border-right:none;border-bottom:1px solid var(--bd)}
}

/* ===== LIGHT MODE OVERRIDES ===== */
[data-theme="light"] nav{background:rgba(245,244,240,.95);border-bottom-color:var(--bd)}
[data-theme="light"] .hero-bg-grad{background:linear-gradient(to top,rgba(245,244,240,1) 0%,rgba(245,244,240,.6) 50%,rgba(245,244,240,.3) 100%)}
[data-theme="light"] .hero-strip{background:rgba(255,255,255,.92);border-top:1px solid var(--bd)}
[data-theme="light"] .hero-strip-item{border-right-color:var(--bd)}
[data-theme="light"] .strip-num{color:#9A7A28}
[data-theme="light"] .strip-lbl{color:#6B6A64}
[data-theme="light"] .disc-bar{background:rgba(245,244,240,.97)}
[data-theme="light"] .feat-grid{background:var(--s1);border-color:var(--bd)}
[data-theme="light"] .feat-info{background:var(--s1)}
[data-theme="light"] .ov-bg{background:rgba(0,0,0,.35)}
[data-theme="light"] .lb-bg{background:rgba(0,0,0,.75)}
[data-theme="light"] .cart-badge{color:#fff}
[data-theme="light"] .btn-g{color:#fff}
[data-theme="light"] .btn-t{color:#fff}
[data-theme="light"] .mob-menu{background:var(--s1)}
[data-theme="light"] .ig-av{background:linear-gradient(135deg,var(--g),var(--t))}
[data-theme="light"] .tag-g{background:rgba(184,134,46,.12);border-color:rgba(184,134,46,.25)}
[data-theme="light"] .visit-badge{background:rgba(184,134,46,.08);border-color:rgba(184,134,46,.2)}
[data-theme="light"] .lbl{color:#9A7A28}
[data-theme="light"] .h2{color:#1A1A18}
[data-theme="light"] img{filter:none}
[data-theme="light"] .gal-ov{color:#fff}
[data-theme="light"] .gal-ov .tag{color:#fff}
[data-theme="light"] .port-ov{color:#fff}
[data-theme="light"] .port-ov .tag{color:#fff;border-color:rgba(255,255,255,.3)}
[data-theme="light"] .feat-browse-hint{color:#fff}
.theme-btn{
  background:none;border:1px solid var(--bd2);color:var(--g);
  padding:7px 10px;cursor:pointer;transition:all .2s;display:flex;align-items:center;
}
.theme-btn:hover{border-color:var(--g);color:var(--gl)}
[data-theme="light"] .theme-btn{color:var(--gr)}
[data-theme="light"] .theme-btn:hover{color:var(--g)}

/* ===== QR ADMIN PANEL ===== */
.qr-split{display:grid;grid-template-columns:280px 1fr;gap:0;min-height:calc(100vh - 80px)}
.qr-sidebar{background:var(--s1);border-right:1px solid var(--bd);display:flex;flex-direction:column;padding:16px;overflow:hidden;border-radius:8px 0 0 8px}
.qr-main{padding:0 0 0 24px;overflow-y:auto;min-width:0}
@media(max-width:700px){.qr-split{grid-template-columns:1fr}.qr-sidebar{display:none}}
.qr-tabs{display:flex;gap:0;border-bottom:1px solid var(--bd);margin-bottom:24px}
.qr-tab{background:none;border:none;color:var(--gr);font-family:'Space Mono',monospace;font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:10px 18px;cursor:pointer;border-bottom:2px solid transparent;display:flex;align-items:center;gap:6px;transition:all .15s}
.qr-tab:hover{color:var(--t)}
.qr-tab.act{color:var(--g);border-bottom-color:var(--g)}
.qr-panel{display:none}
.qr-panel.act{display:block}
.designer{display:grid;grid-template-columns:1fr 340px;gap:24px}
@media(max-width:700px){.designer{grid-template-columns:1fr}}
.designer-preview{display:flex;flex-direction:column;align-items:center;gap:16px;position:sticky;top:24px}
.qr-preview-frame{width:300px;height:300px;background:var(--s2);border:1px solid var(--bd);border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.qr-preview-frame svg{width:100%;height:100%}
.fselect{width:100%;padding:10px 12px;background:var(--s2);border:1px solid var(--bd);color:var(--w);font-size:13px;font-family:inherit;outline:none;border-radius:4px;cursor:pointer}
.fselect option{background:var(--s2);color:var(--w)}
.fslider{-webkit-appearance:none;width:100%;height:4px;background:var(--bd);outline:none;border-radius:2px}
.fslider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--g);border-radius:50%;cursor:pointer}
.color-row{display:flex;gap:12px;align-items:center}
.color-swatch{width:36px;height:36px;border:2px solid var(--bd);border-radius:6px;cursor:pointer;flex-shrink:0;position:relative;overflow:hidden}
.color-swatch input{opacity:0;position:absolute;inset:0;width:100%;height:100%;cursor:pointer}
.preset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;margin-bottom:16px}
.preset{padding:12px;background:var(--s2);border:1px solid var(--bd);border-radius:6px;cursor:pointer;text-align:center;font-size:11px;color:var(--gr);transition:all .15s}
.preset:hover,.preset.act{border-color:var(--g);color:var(--g)}
.preset-dot{width:24px;height:24px;border-radius:4px;margin:0 auto 6px;border:1px solid var(--bd)}
.logo-drop{border:2px dashed var(--bd);border-radius:8px;padding:24px;text-align:center;cursor:pointer;transition:all .15s;color:var(--grd)}
.logo-drop:hover,.logo-drop.drag{border-color:var(--g);color:var(--g);background:var(--gd)}
.logo-drop img{max-width:80px;max-height:80px;margin:8px auto;display:block;border-radius:4px}
.sec-head{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--gr);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--bd)}
.qr-card{background:var(--s1);border:1px solid var(--bd);border-radius:8px;padding:16px;display:flex;gap:16px;align-items:center;margin-bottom:12px}
.qr-card-preview{width:80px;height:80px;flex-shrink:0;background:var(--s2);border-radius:4px;overflow:hidden}
.qr-card-preview svg{width:100%;height:100%}
.qr-card-info{flex:1;min-width:0}
.qr-card-title{font-size:14px;margin-bottom:4px}
.qr-card-meta{font-size:11px;color:var(--gr)}
.qr-card-actions{display:flex;gap:6px;flex-shrink:0}
.stat-card{background:var(--s1);border:1px solid var(--bd);border-radius:8px;padding:18px}
.stat-label{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--gr);margin-bottom:8px}
.stat-value{font-family:'Cormorant Garamond',Georgia,serif;font-size:36px;font-weight:300;color:var(--w);line-height:1}
.stat-sub{font-size:11px;color:var(--grd);margin-top:4px}
.chart-bar{position:absolute;bottom:0;background:var(--g);border-radius:2px 2px 0 0;min-height:1px;transition:height .3s}
.chart-bar-reg{position:absolute;bottom:0;background:var(--t);border-radius:2px 2px 0 0;min-height:1px;transition:height .3s}
.slug-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--bd);cursor:pointer}
.slug-row:last-child{border-bottom:none}
.slug-row:hover{background:var(--gd);margin:0 -8px;padding:8px}
.slug-bar{height:6px;background:var(--g);border-radius:3px;transition:width .3s}
.scan-row{display:grid;grid-template-columns:1.2fr 0.8fr 0.8fr 0.8fr 1fr;gap:8px;padding:8px 0;border-bottom:1px solid var(--bd);font-size:12px;color:var(--gr)}
.scan-row:first-child{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--grd)}
.reg-row{display:grid;grid-template-columns:1fr 1.5fr 1fr auto;gap:8px;padding:8px 0;border-bottom:1px solid var(--bd);font-size:12px;color:var(--gr)}
.reg-row:first-child{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--grd)}
.device-bar{display:flex;align-items:center;gap:8px;padding:6px 0}
.device-bar-fill{height:8px;border-radius:4px;transition:width .3s}
.device-bar-label{font-family:'Space Mono',monospace;font-size:11px;min-width:70px;color:var(--gr)}
.device-bar-count{font-family:'Space Mono',monospace;font-size:11px;color:var(--g);min-width:40px;text-align:right}
.heatmap-grid{display:grid;grid-template-columns:40px repeat(24,1fr);gap:2px;font-family:'Space Mono',monospace;font-size:8px}
.heatmap-cell{aspect-ratio:1;border-radius:2px;position:relative;cursor:default}
.heatmap-cell:hover::after{content:attr(title);position:absolute;bottom:calc(100% + 4px);left:50%;transform:translateX(-50%);background:var(--s2);border:1px solid var(--bd);padding:4px 8px;border-radius:4px;font-size:9px;white-space:nowrap;z-index:10;color:var(--w)}
.heatmap-hour{color:var(--grd);text-align:center;font-size:8px;line-height:1}
.heatmap-day{color:var(--grd);display:flex;align-items:center;font-size:9px}
.scan-toast{position:fixed;top:20px;right:20px;background:var(--s2);border:1px solid var(--g);border-radius:8px;padding:14px 20px;font-size:13px;color:var(--w);z-index:9999;animation:slideIn .3s ease;box-shadow:0 4px 20px rgba(0,0,0,.4)}
.scan-toast .toast-dot{display:inline-block;width:8px;height:8px;background:var(--grn);border-radius:50%;margin-right:8px;animation:qrPulse 1s infinite}
/* QR Tree View */
.qr-tree-folder{margin-bottom:2px}
.qr-tree-head{display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer;border-radius:6px;transition:background .15s;font-size:13px}
.qr-tree-head:hover{background:var(--s2)}
.qr-tree-head .chevron{width:12px;height:12px;transition:transform .15s;flex-shrink:0;color:var(--grd)}
.qr-tree-head.open .chevron{transform:rotate(90deg)}
.qr-tree-head .folder-icon{width:14px;height:14px;color:var(--g);flex-shrink:0}
.qr-tree-count{font-family:'Space Mono',monospace;font-size:9px;color:var(--grd);margin-left:auto}
.qr-tree-items{display:none;padding-left:20px}
.qr-tree-folder.open>.qr-tree-items{display:block}
.qr-tree-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-bottom:1px solid var(--bd);transition:background .15s;border-radius:4px;margin-bottom:2px}
.qr-tree-item:hover{background:var(--s2)}
.qr-tree-item .qr-mini{width:48px;height:48px;flex-shrink:0;background:var(--s2);border-radius:4px;overflow:hidden}
.qr-tree-item .qr-mini svg{width:100%;height:100%}
.qr-tree-item-info{flex:1;min-width:0}
.qr-tree-item-actions{display:flex;gap:2px;margin-bottom:2px}
.qr-tree-item-title{font-size:12px;color:var(--w);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qr-tree-unfiled{margin-top:8px;padding-top:8px;border-top:1px solid var(--bd)}
.qr-tree-item[draggable="true"]{cursor:grab}
.qr-tree-item.dragging{opacity:.4}
.qr-tree-head.drag-over{background:var(--gd);border:1px dashed var(--g)}
.qr-tree-item-date{font-family:'Space Mono',monospace;font-size:9px;color:var(--grd);margin-top:2px}
@keyframes slideIn{from{transform:translateX(100px);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes qrPulse{0%,100%{opacity:1}50%{opacity:.3}}
