/* ============ ToolRent — Design System ============ */
:root{
  --navy:#0B1F3A;
  --navy-2:#0E2748;
  --blue:#1E50E6;
  --blue-dark:#1840BE;
  --blue-soft:#EAF0FE;
  --ink:#15212E;
  --slate:#5A6B82;
  --slate-2:#8493A7;
  --line:#E3E8EF;
  --line-2:#EEF1F6;
  --bg:#F4F6FA;
  --white:#ffffff;
  --green:#1F9D57;
  --green-soft:#E6F5EC;
  --amber:#E0A011;
  --amber-soft:#FBF1D8;
  --red:#D23B3B;
  --shadow-sm:0 1px 2px rgba(16,34,64,.06), 0 1px 3px rgba(16,34,64,.05);
  --shadow:0 4px 14px rgba(16,34,64,.08);
  --shadow-lg:0 18px 50px rgba(16,34,64,.16);
  --r:10px;
  --r-lg:16px;
  --maxw:1280px;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:"IBM Plex Sans Thai","IBM Plex Sans",system-ui,sans-serif;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
}
h1,h2,h3,h4{font-family:"Anuphan","IBM Plex Sans Thai",sans-serif;margin:0;line-height:1.12;letter-spacing:-.01em;}
p{margin:0;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
input,select,textarea{font-family:inherit;font-size:15px;}
img{display:block;max-width:100%;}
:focus-visible{outline:3px solid rgba(30,80,230,.4);outline-offset:2px;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;width:100%;}
.app-root{min-height:100vh;display:flex;flex-direction:column;}
.flex{display:flex;}
.col{display:flex;flex-direction:column;}
.center{align-items:center;}
.between{justify-content:space-between;}
.gap8{gap:8px;}.gap12{gap:12px;}.gap16{gap:16px;}.gap24{gap:24px;}
.muted{color:var(--slate);}
.eyebrow{font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--slate);}
.section{padding:56px 0;}
.section-head{margin-bottom:28px;}
.section-head h2{font-size:42px;font-weight:700;color:var(--navy);margin-top:6px;}

/* ====== Buttons ====== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:600;font-size:15px;border-radius:8px;padding:12px 22px;transition:.15s;white-space:nowrap;}
.btn-primary{background:var(--blue);color:#fff;}
.btn-primary:hover{background:var(--blue-dark);}
.btn-dark{background:var(--navy);color:#fff;}
.btn-dark:hover{background:#13335c;}
.btn-ghost{background:#fff;color:var(--blue);border:1.5px solid var(--blue);}
.btn-ghost:hover{background:var(--blue-soft);}
.btn-line{background:#fff;color:var(--ink);border:1.5px solid var(--line);}
.btn-line:hover{border-color:var(--slate-2);}
.btn-block{width:100%;}
.btn-lg{padding:15px 28px;font-size:16px;}
.btn-sm{padding:8px 14px;font-size:13.5px;border-radius:7px;}
.btn:disabled{opacity:.5;cursor:not-allowed;}

/* ====== Badges ====== */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;
  padding:4px 10px;border-radius:100px;}
.badge-green{background:var(--green-soft);color:var(--green);}
.badge-amber{background:var(--amber-soft);color:#9a6c06;}
.badge-blue{background:var(--blue-soft);color:var(--blue-dark);}
.badge-gray{background:#EEF1F6;color:var(--slate);}
.dot{width:7px;height:7px;border-radius:50%;background:currentColor;}

/* ====== Placeholder image ====== */
.ph{position:relative;background:
   repeating-linear-gradient(135deg,#E9EEF5 0 14px,#E1E8F1 14px 28px);
   display:flex;align-items:center;justify-content:center;overflow:hidden;color:#90A0B5;}
.ph::after{content:attr(data-label);font-family:"IBM Plex Mono",ui-monospace,monospace;
   font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;
   background:rgba(255,255,255,.78);border-radius:5px;border:1px solid #D5DEEA;color:#7B8AA0;}
.ph-img{background:#fff;}
.ph-img img{width:100%;height:100%;object-fit:cover;display:block;}
.ph-img::after{display:none;}
.ph-dark{background:repeating-linear-gradient(135deg,#1a3052 0 14px,#16294a 14px 28px);}
.ph-dark::after{background:rgba(11,31,58,.6);color:#9fb4d2;border-color:#26405f;}

/* ====== Header ====== */
.hdr{background:var(--navy);color:#fff;position:sticky;top:0;z-index:60;}
.hdr-top{font-size:13px;background:#081a31;}
.hdr-top .wrap{display:flex;justify-content:flex-end;align-items:center;gap:22px;height:38px;}
.hdr-top a,.hdr-top span{color:#b9c6da;display:inline-flex;align-items:center;gap:6px;}
.hdr-top a:hover{color:#fff;}
.hdr-main .wrap{display:flex;align-items:center;gap:28px;height:68px;}
.logo{display:flex;align-items:center;gap:11px;cursor:pointer;}
.logo-img{height:42px;width:auto;display:block;}
.logo-mark{width:38px;height:42px;flex:none;}
.logo-tx{line-height:1;}
.logo-tx b{font-family:"Anuphan",sans-serif;font-size:22px;font-weight:700;letter-spacing:-.02em;color:#fff;display:block;}
.logo-tx small{font-size:10.5px;letter-spacing:.18em;color:#7e93b3;text-transform:uppercase;font-weight:600;}
.nav{display:flex;align-items:center;gap:6px;margin-left:6px;}
.nav a{padding:8px 13px;border-radius:7px;font-weight:600;font-size:15px;color:#dce5f1;}
.nav a:hover,.nav a.active{background:rgba(255,255,255,.1);color:#fff;}
.hdr-actions{margin-left:auto;display:flex;align-items:center;gap:14px;}
.hdr-search{display:flex;align-items:center;gap:9px;background:#fff;
  border:1.5px solid rgba(255,255,255,.55);border-radius:9px;padding:0 12px;height:42px;
  width:180px;transition:.15s;}
.hdr-search:focus-within{background:#fff;border-color:var(--blue);width:210px;}
.hdr-search svg{color:#7488a3;flex:none;}
.hdr-search input{flex:1;background:none;border:none;outline:none;color:#1a2536;font-size:14.5px;
  font-family:inherit;min-width:0;}
.hdr-search input::placeholder{color:#8b9bb2;}
@media(max-width:1100px){.hdr-search{width:200px;}.hdr-search:focus-within{width:220px;}}
.icon-btn{width:40px;height:40px;border-radius:8px;color:#dce5f1;display:flex;align-items:center;justify-content:center;position:relative;}
.icon-btn:hover{background:rgba(255,255,255,.1);color:#fff;}
.cart-count{position:absolute;top:2px;right:2px;background:var(--amber);color:#3a2900;font-size:11px;font-weight:700;
  min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;}

/* mini cart preview popover (shows for 10s after add-to-cart) */
.cart-anchor{position:relative;}
.cart-flash{position:absolute;top:calc(100% + 14px);right:-6px;width:312px;background:#fff;border-radius:14px;
  box-shadow:0 18px 48px rgba(7,20,38,.28);padding:14px 14px 0;z-index:120;color:var(--ink);
  transform-origin:top right;animation:flashIn .26s cubic-bezier(.2,.9,.3,1.2);overflow:hidden;}
.cart-flash-arrow{position:absolute;top:-7px;right:18px;width:14px;height:14px;background:#fff;transform:rotate(45deg);
  box-shadow:-3px -3px 8px rgba(7,20,38,.06);}
.cart-flash-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px;}
.cart-flash-ok{display:flex;align-items:center;gap:6px;color:var(--green);font-weight:700;font-size:13.5px;}
.cart-flash-x{width:26px;height:26px;border-radius:7px;color:var(--slate);display:flex;align-items:center;justify-content:center;}
.cart-flash-x:hover{background:var(--bg);color:var(--ink);}
.cart-flash-body{display:flex;gap:12px;align-items:center;}
.cart-flash-img{width:62px;height:62px;border-radius:10px;flex:none;}
.cart-flash-info{min-width:0;flex:1;}
.cart-flash-name{font-weight:700;font-size:15px;color:var(--navy);line-height:1.3;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.cart-flash-code{font-size:12px;color:var(--slate);margin-top:2px;}
.cart-flash-meta{display:flex;align-items:baseline;gap:10px;margin-top:7px;}
.cart-flash-rate{font-family:"Anuphan",sans-serif;font-weight:700;font-size:17px;color:var(--blue);}
.cart-flash-rate i{font-style:normal;font-size:12.5px;font-weight:500;color:var(--slate);}
.cart-flash-qty{font-size:13px;font-weight:600;color:var(--ink);}
.cart-flash-cta{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;margin-top:13px;
  background:var(--blue);color:#fff;font-weight:600;font-size:14px;padding:10px;border-radius:9px;}
.cart-flash-cta:hover{background:var(--blue-dark);}
.cart-flash-timer{height:3px;margin:13px -14px 0;background:var(--blue);opacity:.9;
  transform-origin:left;animation:flashTimer 10s linear forwards;}
@keyframes flashIn{from{opacity:0;transform:translateY(-8px) scale(.96);}to{opacity:1;transform:none;}}
@keyframes flashTimer{from{transform:scaleX(1);}to{transform:scaleX(0);}}
@media(max-width:560px){.cart-flash{position:fixed;top:auto;bottom:16px;right:12px;left:12px;width:auto;}.cart-flash-arrow{display:none;}}
.signin-pill{background:var(--blue);color:#fff;border-radius:8px;padding:9px 16px;font-weight:600;font-size:14.5px;display:flex;align-items:center;gap:8px;}
.signin-pill:hover{background:var(--blue-dark);}
.burger{display:none;}
.user-pill{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);
  border-radius:8px;padding:6px 12px 6px 6px;color:#fff;font-weight:600;font-size:14px;}
.avatar{width:30px;height:30px;border-radius:7px;background:var(--blue);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;}

/* booking strip under header */
.bookbar{background:var(--navy-2);border-top:1px solid rgba(255,255,255,.07);transition:background .2s;}
.bookbar.err{background:#3a1620;border-top-color:rgba(210,59,59,.5);}
.bookbar .wrap{display:flex;gap:10px;padding:12px 28px;flex-wrap:wrap;}
.bookbar-lead{flex-basis:100%;display:flex;align-items:center;gap:8px;color:#aebfd6;font-size:13px;font-weight:500;margin-bottom:2px;}
.bookbar-lead svg{flex:none;color:#7e9fd6;}
.bookbar.err .bookbar-lead{color:#ffd0d0;}
.bookbar.err .bookbar-lead svg{color:#ff9a9a;}
.bookbar-hint{flex-basis:100%;display:flex;align-items:center;gap:8px;color:#ffd0d0;font-size:13.5px;font-weight:600;margin-bottom:2px;}
.bookbar-hint svg{color:#ff9a9a;flex:none;}
.bookfield{flex:1;min-width:170px;background:#fff;border-radius:8px;padding:9px 12px;display:flex;align-items:center;gap:9px;color:var(--ink);font-size:14px;border:2px solid transparent;}
.bookfield.method{flex:0 0 230px;}
.bf-stack{display:flex;flex-direction:column;flex:1;min-width:0;gap:1px;}
.bf-stack input{padding:0;border:0;background:transparent;width:100%;font-size:14px;color:var(--ink);}
.bf-cap{font-size:10px;font-weight:700;letter-spacing:.02em;color:var(--slate);line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.bookfield.step.locked .bf-cap{color:var(--slate-2);}
.bookfield.method select{font-weight:600;color:var(--blue);}
.bookfield.err{border-color:var(--red);box-shadow:0 0 0 3px rgba(210,59,59,.25);animation:shake .3s;}
/* progressive step states */
.bookfield.step{position:relative;transition:opacity .2s,border-color .2s,box-shadow .2s;}
.bookfield.step.locked{opacity:.5;background:#e9edf3;border-color:transparent;}
.bookfield.step.locked input,.bookfield.step.locked select{pointer-events:none;color:var(--slate-2);}
.bookfield.step.active{border-color:var(--blue);box-shadow:0 0 0 3px rgba(30,80,230,.18);}
.bookfield.step.active.err,.bookbar.err .bookfield.step.active{border-color:var(--red);box-shadow:0 0 0 3px rgba(210,59,59,.25);animation:shake .3s;}
.bookfield.step.done{border-color:#bfe3cd;}
.stp-badge{flex:none;width:21px;height:21px;border-radius:50%;background:var(--line-2);color:var(--slate);
  font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:"Anuphan",sans-serif;}
.bookfield.step.active .stp-badge{background:var(--blue);color:#fff;animation:pulse 1.4s ease-in-out infinite;}
.stp-badge.ok{background:var(--green);color:#fff;}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(30,80,230,.5);}50%{box-shadow:0 0 0 5px rgba(30,80,230,0);}}
.map-affd{flex:none;color:var(--blue);display:flex;align-items:center;gap:4px;font-size:12.5px;font-weight:600;white-space:nowrap;}
@keyframes shake{0%,100%{transform:translateX(0);}25%{transform:translateX(-4px);}75%{transform:translateX(4px);}}
.bookfield svg{color:var(--blue);flex:none;}
.bookfield input,.bookfield select{border:none;outline:none;width:100%;background:transparent;color:var(--ink);}
.bookfield .lbl{color:var(--slate-2);}
.bookfield.jobsite{cursor:pointer;}
.bookfield.jobsite:hover{box-shadow:0 0 0 2px var(--blue);}
.bookfield .map-affd{margin-left:auto;color:var(--blue);display:flex;flex:none;}

/* ====== Footer ====== */
.ftr{background:var(--navy);color:#c3cfe0;margin-top:auto;}
.ftr .wrap{padding:54px 28px 30px;}
.ftr-grid{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:34px;}
.ftr h5{color:#fff;font-size:14px;font-weight:700;letter-spacing:.04em;margin-bottom:14px;}
.ftr ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px;}
.ftr a{font-size:14px;color:#9fb0c8;}
.ftr a:hover{color:#fff;}
.ftr-bot{border-top:1px solid rgba(255,255,255,.1);margin-top:36px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;color:#7e93b3;}

/* ====== Cards / grid ====== */
.cat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;}
.cat-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:16px;cursor:pointer;
  display:flex;flex-direction:column;justify-content:space-between;min-height:108px;transition:.15s;}
.cat-card:hover{border-color:var(--blue);box-shadow:var(--shadow);transform:translateY(-2px);}
.cat-card .nm{font-weight:600;font-size:15px;color:var(--ink);max-width:78%;line-height:1.25;}
.cat-card .ic{align-self:flex-end;color:var(--navy);opacity:.9;}

.sol-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.sol-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:.15s;box-shadow:var(--shadow-sm);}
.sol-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);}
.sol-card .ph{height:190px;}
.sol-card .body{padding:18px 18px 22px;}
.sol-card .eyebrow{color:var(--blue);font-size:12px;}
.sol-card h3{font-size:21px;color:var(--navy);margin-top:6px;font-weight:700;}

.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.prod-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:.15s;}
.prod-card:hover{box-shadow:var(--shadow);border-color:#cdd7e4;}
.prod-card .ph{height:170px;cursor:pointer;}
.prod-card .body{padding:15px 15px 17px;display:flex;flex-direction:column;flex:1;gap:7px;}
.prod-card .cat{color:var(--blue);font-weight:600;font-size:12.5px;}
.prod-card h4{font-size:16.5px;color:var(--ink);font-weight:600;cursor:pointer;line-height:1.25;}
.prod-card h4:hover{color:var(--blue);}
.rate-row{display:flex;gap:14px;font-size:13px;color:var(--slate);margin-top:2px;flex-wrap:wrap;}
.rate-row b{color:var(--ink);font-size:15px;font-family:"Anuphan",sans-serif;}
.prod-card .foot{margin-top:auto;display:flex;gap:8px;padding-top:8px;}
/* rate picker on cards */
.ratepick{margin-top:4px;}
.ratepick-lbl{font-size:11.5px;font-weight:700;letter-spacing:.04em;color:var(--slate-2);text-transform:uppercase;margin-bottom:6px;}
.ratepick-opts{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;}
.rateopt{display:flex;flex-direction:column;align-items:center;gap:0;padding:6px 2px;border:1.5px solid var(--line);
  border-radius:8px;background:#fff;transition:.13s;line-height:1.12;overflow:hidden;}
.rateopt:hover{border-color:var(--blue);background:var(--blue-soft);}
.rateopt.on{border-color:var(--blue);background:var(--blue);}
.rateopt .rt-p{font-size:12px;font-weight:700;color:var(--ink);font-family:"Anuphan",sans-serif;white-space:nowrap;}
.rateopt .rt-u{font-size:10px;color:var(--slate);white-space:nowrap;}
.rateopt.on .rt-p,.rateopt.on .rt-u{color:#fff;}

/* ====== Hero ====== */
.hero{background:radial-gradient(1200px 500px at 80% -10%,#16335f 0%,var(--navy) 55%);color:#fff;position:relative;overflow:hidden;}
.hero::before{content:"";position:absolute;inset:0;background-image:
  repeating-radial-gradient(circle at 12% 50%,transparent 0 78px,rgba(255,255,255,.04) 78px 80px);pointer-events:none;}
.hero .wrap{display:grid;grid-template-columns:1.05fr 1fr;gap:46px;align-items:center;padding:64px 28px 70px;position:relative;}
.hero h1{font-size:60px;font-weight:700;line-height:1.04;letter-spacing:-.02em;}
.hero .sub{font-size:21px;color:#c3d2ea;margin-top:18px;max-width:520px;}
.hero .pts{display:flex;gap:22px;margin:26px 0 30px;flex-wrap:wrap;}
.hero .pt{display:flex;align-items:center;gap:9px;font-size:14.5px;color:#dbe6f5;}
.hero .pt svg{color:#5ee0a0;flex:none;}
.hero-art{height:380px;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);}

/* ====== Hero v2 (full-bleed image + search) ====== */
.hero2{position:relative;color:#fff;overflow:hidden;background:var(--navy);}
.hero2-bg{position:absolute;inset:0;}
.hero2-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(7,18,36,.93) 0%,rgba(8,22,44,.82) 42%,rgba(8,22,44,.45) 100%);}
.hero2 .wrap{position:relative;padding:60px 28px 0;}
.hero2-inner{max-width:680px;padding-bottom:34px;}
.hero2 .eyebrow{color:#8fb0e0;}
.hero2 h1{font-size:58px;font-weight:700;line-height:1.05;letter-spacing:-.02em;margin-top:14px;}
.hero2 .sub{font-size:20px;color:#cdd9ec;margin-top:16px;max-width:540px;}
.hero2 .pts{display:flex;gap:22px;margin-top:22px;flex-wrap:wrap;}
.hero2 .pt{display:flex;align-items:center;gap:8px;font-size:14.5px;color:#dbe6f5;}
.hero2 .pt svg{color:#5ee0a0;flex:none;}

/* search card */
.hsearch{background:#fff;border-radius:14px;box-shadow:var(--shadow-lg);padding:10px;display:flex;gap:8px;
  align-items:stretch;position:relative;margin-top:30px;max-width:920px;}
.hsearch .grp{display:flex;align-items:center;gap:11px;padding:0 16px;flex:1;min-width:0;}
.hsearch .grp + .grp{border-left:1px solid var(--line);}
.hsearch .grp svg{color:var(--blue);flex:none;}
.hsearch .grp .lbl{font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--slate-2);display:block;margin-bottom:1px;}
.hsearch input,.hsearch select{border:none;outline:none;width:100%;font-size:15.5px;color:var(--ink);background:transparent;font-weight:500;}
.hsearch input::placeholder{color:#9aa8bd;font-weight:400;}
.hsearch .go{flex:none;}
.hsearch-tags{display:flex;gap:9px;flex-wrap:wrap;margin-top:16px;align-items:center;}
.hsearch-tags .t{font-size:13.5px;color:#cdd9ec;}
.hsearch-tags a{font-size:13.5px;color:#fff;border:1px solid rgba(255,255,255,.28);border-radius:100px;padding:5px 13px;cursor:pointer;transition:.15s;}
.hsearch-tags a:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.5);}

/* jobsite ribbon */
.jobsite-bar{position:relative;background:rgba(255,255,255,.07);border-top:1px solid rgba(255,255,255,.1);margin-top:34px;}
.jobsite-bar .wrap{display:flex;align-items:center;gap:14px;padding:15px 28px;flex-wrap:wrap;}
.jobsite-bar .pin{width:38px;height:38px;border-radius:9px;background:var(--blue);display:flex;align-items:center;justify-content:center;flex:none;}
.jobsite-bar b{color:#fff;font-size:15px;}
.jobsite-bar .meta{color:#aebfd6;font-size:13.5px;}
.jobsite-bar .chg{margin-left:auto;color:#fff;font-weight:600;font-size:14px;border:1.5px solid rgba(255,255,255,.3);border-radius:8px;padding:8px 16px;cursor:pointer;}
.jobsite-bar .chg:hover{background:rgba(255,255,255,.12);}

/* ====== Category image tiles ====== */
.tile-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;}
.tile{position:relative;border-radius:var(--r);overflow:hidden;cursor:pointer;aspect-ratio:1/.86;box-shadow:var(--shadow-sm);}
.tile .ph{position:absolute;inset:0;height:100%;}
.tile .ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,18,36,.9) 8%,rgba(7,18,36,.15) 60%,rgba(7,18,36,.35) 100%);}
.tile .tx{position:absolute;left:0;right:0;bottom:0;padding:15px 16px;color:#fff;display:flex;align-items:flex-end;justify-content:space-between;gap:8px;}
.tile .tx b{font-size:16px;font-weight:600;line-height:1.2;font-family:"Anuphan",sans-serif;}
.tile .tx .ct{font-size:12px;color:#bcd; white-space:nowrap;}
.tile .cic{position:absolute;top:12px;left:12px;width:38px;height:38px;border-radius:9px;background:rgba(255,255,255,.16);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;color:#fff;}
.tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);transition:.18s;}
.tile:hover .ov{background:linear-gradient(to top,rgba(11,31,58,.92) 8%,rgba(30,80,230,.28) 70%,rgba(30,80,230,.15) 100%);}

/* ====== Horizontal rail ====== */
.rail-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:22px;gap:16px;flex-wrap:wrap;}
.rail-wrap{position:relative;}
.rail{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(264px,1fr);gap:18px;overflow-x:auto;
  scroll-snap-type:x mandatory;padding:4px 2px 16px;scrollbar-width:thin;}
.rail::-webkit-scrollbar{height:8px;}
.rail::-webkit-scrollbar-thumb{background:#c9d3e0;border-radius:4px;}
.rail > *{scroll-snap-align:start;}
.rail-btn{position:absolute;top:42%;width:46px;height:46px;border-radius:50%;background:#fff;box-shadow:var(--shadow);
  display:flex;align-items:center;justify-content:center;color:var(--navy);z-index:3;border:1px solid var(--line);}
.rail-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue);}
.rail-btn.l{left:-14px;}.rail-btn.r{right:-14px;}

/* ====== Promo banner ====== */
.promo{position:relative;border-radius:var(--r-lg);overflow:hidden;color:#fff;min-height:240px;display:flex;align-items:center;}
.promo .ph{position:absolute;inset:0;height:100%;}
.promo .ov{position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,22,44,.94) 0%,rgba(8,22,44,.7) 55%,rgba(8,22,44,.25) 100%);}
.promo .ct{position:relative;padding:38px 44px;max-width:600px;}
.promo h2{font-size:34px;color:#fff;}

/* ====== Tabs ====== */
.tabs{display:flex;gap:26px;border-bottom:1px solid var(--line);margin-bottom:26px;flex-wrap:wrap;}
.tab{padding:0 0 12px;font-weight:600;font-size:16px;color:var(--slate);border-bottom:3px solid transparent;margin-bottom:-1px;cursor:pointer;}
.tab.active{color:var(--blue);border-color:var(--blue);}
.tab:hover{color:var(--ink);}

/* ====== Catalog layout ====== */
.catalog{display:grid;grid-template-columns:268px 1fr;gap:34px;align-items:start;}
.side{position:sticky;top:118px;}
.side h4{font-size:15px;margin-bottom:12px;color:var(--ink);}
.searchbox{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:10px 13px;margin-bottom:22px;}
.searchbox input{border:none;outline:none;width:100%;}
.side-block{border-top:1px solid var(--line);padding:18px 0;}
.side-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px;}
.side-list li{padding:7px 10px;border-radius:7px;cursor:pointer;font-size:14.5px;color:var(--slate);display:flex;justify-content:space-between;}
.side-list li:hover{background:var(--blue-soft);color:var(--blue-dark);}
.side-list li.active{background:var(--blue-soft);color:var(--blue-dark);font-weight:600;}
.check{display:flex;align-items:center;gap:9px;font-size:14.5px;color:var(--slate);padding:6px 0;cursor:pointer;}
.check input{width:16px;height:16px;accent-color:var(--blue);}
.crumb{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--slate);margin-bottom:14px;flex-wrap:wrap;}
.crumb a{color:var(--blue);font-weight:500;cursor:pointer;}
.crumb a:hover{text-decoration:underline;}

/* list rows */
.list-row{display:grid;grid-template-columns:120px 1fr auto;gap:18px;background:#fff;border:1px solid var(--line);
  border-radius:var(--r);padding:16px;align-items:center;}
.list-row .ph{height:88px;border-radius:8px;}
.list-row h4{font-size:17px;color:var(--ink);}
.list-row h4:hover{color:var(--blue);cursor:pointer;}
.catclass{font-size:12.5px;color:var(--slate-2);font-family:"IBM Plex Mono",monospace;}
.list-actions{display:flex;flex-direction:column;gap:8px;width:170px;}

/* ====== Forms / auth ====== */
.authpage{display:grid;grid-template-columns:1fr 460px;min-height:calc(100vh - 106px);}
.auth-aside{background:radial-gradient(900px 500px at 20% 0%,#16335f,var(--navy));color:#fff;padding:64px 56px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;}
.auth-aside::before{content:"";position:absolute;inset:0;background-image:repeating-radial-gradient(circle at 90% 100%,transparent 0 78px,rgba(255,255,255,.04) 78px 80px);}
.auth-aside h2{font-size:40px;font-weight:700;line-height:1.08;position:relative;}
.auth-aside .lead{font-size:17px;color:#c3d2ea;margin-top:16px;position:relative;max-width:380px;}
.auth-aside ul{list-style:none;padding:0;margin:30px 0 0;display:flex;flex-direction:column;gap:16px;position:relative;}
.auth-aside li{display:flex;gap:13px;align-items:flex-start;color:#dbe6f5;font-size:15px;}
.auth-aside li svg{color:#5ee0a0;flex:none;margin-top:2px;}
.auth-form{padding:54px 56px;display:flex;flex-direction:column;justify-content:center;max-width:560px;width:100%;margin:0 auto;background:#fff;}
.field{margin-bottom:17px;}
.field label{display:block;font-size:14px;font-weight:600;color:var(--ink);margin-bottom:7px;}
.field .inp,.inp{width:100%;border:1.5px solid var(--line);border-radius:9px;padding:12px 14px;font-size:15px;background:#fff;transition:.15s;}
.field .inp:focus,.inp:focus{border-color:var(--blue);outline:none;box-shadow:0 0 0 3px rgba(30,80,230,.12);}
.field .inp.err{border-color:var(--red);}
.inp.readonly{display:flex;align-items:center;gap:9px;background:var(--line-2);border-color:transparent;color:var(--ink);font-weight:600;cursor:default;}
.field .hint{font-size:12.5px;color:var(--slate-2);margin-top:5px;}
.field .err-msg{font-size:12.5px;color:var(--red);margin-top:5px;}
.inp-group{position:relative;}
.inp-group .suffix{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--slate);font-size:13px;}
.seg{display:flex;background:var(--line-2);border-radius:9px;padding:4px;margin-bottom:24px;}
.seg button{flex:1;padding:10px;border-radius:7px;font-weight:600;font-size:14.5px;color:var(--slate);}
.seg button.active{background:#fff;color:var(--blue);box-shadow:var(--shadow-sm);}
.seg.seg-line{background:transparent;padding:0;gap:10px;}
.seg.seg-line button{border:1.5px solid var(--line);border-radius:9px;background:#fff;}
.seg.seg-line button.active{border-color:var(--blue);background:var(--blue-soft);box-shadow:none;}
.divider{display:flex;align-items:center;gap:14px;color:var(--slate-2);font-size:13px;margin:22px 0;}
.divider::before,.divider::after{content:"";height:1px;background:var(--line);flex:1;}

/* OTP */
.otp-row{display:flex;gap:12px;justify-content:center;margin:14px 0 8px;}
.otp-cell{width:54px;height:62px;text-align:center;font-size:26px;font-weight:700;font-family:"Anuphan",sans-serif;
  border:1.5px solid var(--line);border-radius:11px;color:var(--ink);}
.otp-cell:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(30,80,230,.14);outline:none;}

/* ====== Stepper ====== */
.stepper{display:flex;align-items:center;gap:0;margin:0 auto 8px;max-width:760px;}
.step{display:flex;align-items:center;gap:11px;flex:1;}
.step .num{width:32px;height:32px;border-radius:50%;background:#fff;border:2px solid var(--line);color:var(--slate);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex:none;}
.step .tx{font-size:14px;color:var(--slate);font-weight:600;}
.step.done .num{background:var(--green);border-color:var(--green);color:#fff;}
.step.active .num{background:var(--blue);border-color:var(--blue);color:#fff;}
.step.active .tx{color:var(--ink);}
.step .bar{height:2px;background:var(--line);flex:1;margin:0 4px;}
.step.done .bar{background:var(--green);}

/* ====== Page container ====== */
.page{padding:34px 0 64px;}
.page-narrow{max-width:980px;margin:0 auto;}
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;}
.panel + .panel{margin-top:18px;}
.panel h3{font-size:20px;color:var(--navy);margin-bottom:4px;}

/* summary card */
.summary{position:sticky;top:118px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;}
.summary .head{background:var(--navy);color:#fff;padding:17px 20px;font-weight:700;font-size:17px;}
.summary .body{padding:20px;}
.sum-line{display:flex;justify-content:space-between;font-size:14.5px;padding:7px 0;color:var(--slate);}
.sum-line b{color:var(--ink);}
.sum-line.disc{color:var(--green);}
.sum-line.disc b{color:var(--green);}
/* coupon field */
.coupon{margin-top:12px;}
.coupon-row{display:flex;gap:8px;}
.coupon-inp{flex:1;min-width:0;border:1.5px solid var(--line);border-radius:8px;padding:9px 12px;font-size:14px;
  letter-spacing:.04em;text-transform:uppercase;color:var(--ink);background:#fff;}
.coupon-inp:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft);}
.coupon-inp::placeholder{letter-spacing:normal;text-transform:none;color:var(--slate-2);}
.coupon-btn{flex:none;background:var(--navy);color:#fff;font-weight:600;font-size:14px;padding:0 16px;border-radius:8px;}
.coupon-btn:hover{background:var(--navy-2);}
.coupon-err{display:flex;align-items:center;gap:5px;color:var(--red);font-size:12.5px;margin-top:7px;}
.coupon-applied{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--blue-soft);
  border:1px solid color-mix(in srgb,var(--blue) 25%,transparent);border-radius:9px;padding:9px 12px;font-size:13.5px;color:var(--navy);}
.coupon-applied span{display:flex;align-items:center;gap:7px;}
.coupon-applied b{font-family:"IBM Plex Mono",monospace;letter-spacing:.03em;}
.coupon-applied button{flex:none;width:24px;height:24px;border-radius:6px;color:var(--slate);display:flex;align-items:center;justify-content:center;}
.coupon-applied button:hover{background:#fff;color:var(--red);}

/* coupon admin */
.coupon-form{display:grid;grid-template-columns:1fr 1fr;gap:14px 16px;}
.seg.sm{margin-bottom:0;}
.seg.sm button{padding:8px;font-size:13.5px;}
.inp.mono{font-family:"IBM Plex Mono",monospace;letter-spacing:.05em;text-transform:uppercase;}
.toggle{width:42px;height:24px;border-radius:999px;background:var(--line-2);position:relative;transition:background .18s;flex:none;}
.toggle .knob{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.25);transition:left .18s;}
.toggle.on{background:var(--green);}
.toggle.on .knob{left:21px;}
@media(max-width:680px){.coupon-form{grid-template-columns:1fr;}}
.sum-total{border-top:1px dashed var(--line);margin-top:8px;padding-top:14px;display:flex;justify-content:space-between;align-items:baseline;}
.sum-total .big{font-size:26px;font-weight:700;font-family:"Anuphan",sans-serif;color:var(--navy);}

/* credit card visual */
.cc{background:linear-gradient(135deg,#15335f,#0B1F3A);border-radius:16px;padding:24px;color:#fff;height:200px;
  display:flex;flex-direction:column;justify-content:space-between;box-shadow:var(--shadow-lg);position:relative;overflow:hidden;}
.cc::before{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:50%;background:rgba(94,224,160,.12);}
.cc .chip{width:46px;height:34px;border-radius:6px;background:linear-gradient(135deg,#e8c977,#c8a23f);}
.cc .num{font-family:"IBM Plex Mono",monospace;font-size:21px;letter-spacing:.12em;}
.cc .row{display:flex;justify-content:space-between;font-size:12px;color:#aac0e0;}
.cc .row b{color:#fff;font-size:14px;display:block;font-family:"IBM Plex Mono",monospace;}

.hold-banner{background:var(--amber-soft);border:1px solid #f0dca6;border-radius:11px;padding:15px 17px;display:flex;gap:13px;align-items:flex-start;}
.hold-banner svg{color:var(--amber);flex:none;margin-top:1px;}

/* QR PromptPay payment */
.qrpay{display:grid;grid-template-columns:280px 1fr;gap:24px;align-items:start;}
.qrpay-card{border:1px solid var(--line);border-radius:14px;overflow:hidden;}
.qrpay-top{background:#0B3D8C;color:#fff;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;}
.qrpay-top .muted{color:#bcd!important;}
.pp-logo{font-weight:800;font-size:16px;letter-spacing:.01em;font-family:"Anuphan",sans-serif;}
.qrpay-code{display:flex;justify-content:center;padding:18px;background:#fff;}
.qrpay-amt{display:flex;align-items:baseline;justify-content:space-between;padding:12px 16px;border-top:1px dashed var(--line);}
.qrpay-amt b{font-family:"Anuphan",sans-serif;font-size:24px;color:var(--navy);font-weight:700;}
.qrpay-merchant{padding:12px 16px;border-top:1px solid var(--line-2);display:flex;flex-direction:column;gap:7px;font-size:13.5px;}
.qrpay-merchant b{font-size:13.5px;}
.qrpay-steps h4{font-family:"Anuphan",sans-serif;}
.qr-ol{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:9px;color:var(--slate);font-size:14px;}
.qr-ol li{padding-left:4px;}
.qr-ol b{color:var(--ink);}
@media(max-width:680px){ .qrpay{grid-template-columns:1fr;} .qrpay-card{max-width:300px;margin:0 auto;} }

/* success */
.success-ico{width:84px;height:84px;border-radius:50%;background:var(--green-soft);display:flex;align-items:center;justify-content:center;margin:0 auto 22px;color:var(--green);}

/* table */
.cart-item{display:grid;grid-template-columns:90px 1fr auto;gap:16px;padding:18px 0;border-bottom:1px solid var(--line);align-items:center;}
.cart-item .ph{height:70px;border-radius:8px;}
.qty{display:flex;align-items:center;border:1px solid var(--line);border-radius:8px;overflow:hidden;}
.qty button{width:34px;height:36px;font-size:18px;color:var(--slate);}
.qty button:hover{background:var(--line-2);color:var(--ink);}
.qty span{width:38px;text-align:center;font-weight:600;}

/* misc */
.pill-row{display:flex;gap:8px;flex-wrap:wrap;}
.spec{display:grid;grid-template-columns:1fr 1fr;gap:0 26px;}
.spec .r{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--line-2);font-size:14.5px;}
.spec .r span{color:var(--slate);}
.spec .r b{color:var(--ink);font-weight:600;}
.notice{background:var(--blue-soft);border:1px solid #c9d8fb;border-radius:11px;padding:14px 16px;font-size:14px;color:var(--blue-dark);display:flex;gap:11px;align-items:flex-start;}
.notice svg{flex:none;margin-top:1px;}

/* ====== Map picker modal ====== */
.modal-overlay{position:fixed;inset:0;background:rgba(8,18,34,.55);backdrop-filter:blur(3px);z-index:300;
  display:flex;align-items:center;justify-content:center;padding:24px;animation:fadein .18s ease;}
@keyframes fadein{from{opacity:0;}to{opacity:1;}}
.map-modal{background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:760px;
  max-height:92vh;display:flex;flex-direction:column;overflow:hidden;animation:popin .2s ease;}
@keyframes popin{from{opacity:0;transform:translateY(12px) scale(.98);}to{opacity:1;transform:none;}}
.map-modal-head{display:flex;justify-content:space-between;align-items:flex-start;padding:18px 22px;border-bottom:1px solid var(--line);}
.map-search{display:flex;gap:10px;padding:14px 22px;border-bottom:1px solid var(--line-2);flex-wrap:wrap;}
.map-canvas{position:relative;flex:1;min-height:340px;cursor:crosshair;overflow:hidden;user-select:none;}
.map-svg{position:absolute;inset:0;width:100%;height:100%;}
.map-pin{position:absolute;transform:translate(-50%,-100%);pointer-events:none;filter:drop-shadow(0 6px 8px rgba(0,0,0,.3));animation:pindrop .3s cubic-bezier(.3,1.4,.5,1);}
@keyframes pindrop{0%{transform:translate(-50%,-160%);opacity:0;}100%{transform:translate(-50%,-100%);opacity:1;}}
.map-hint{position:absolute;top:14px;left:50%;transform:translateX(-50%);background:rgba(11,31,58,.85);color:#fff;
  font-size:13.5px;font-weight:500;padding:8px 16px;border-radius:100px;display:flex;align-items:center;gap:7px;pointer-events:none;}
.map-watermark{position:absolute;bottom:8px;right:10px;font-size:11px;color:#6b7c90;background:rgba(255,255,255,.7);padding:2px 8px;border-radius:5px;pointer-events:none;}
.map-modal-foot{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px 22px;border-top:1px solid var(--line);flex-wrap:wrap;}
.map-result{line-height:1.4;}
.jobsite-set{display:flex;align-items:center;gap:6px;width:100%;}
.jobsite-set .pinbtn{flex:none;color:var(--blue);display:flex;align-items:center;}
.jobsite-set .clr{flex:none;color:var(--slate-2);width:22px;height:22px;border-radius:5px;display:flex;align-items:center;justify-content:center;}
.jobsite-set .clr:hover{background:var(--line-2);color:var(--ink);}
@media(max-width:560px){
  .modal-overlay{padding:0;align-items:flex-end;}
  .map-modal{max-width:100%;max-height:96vh;border-radius:16px 16px 0 0;}
  .map-modal-foot{flex-direction:column;align-items:stretch;}
  .map-modal-foot .flex{justify-content:stretch;}
  .map-modal-foot .btn{flex:1;}
}

.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;
  padding:14px 22px;border-radius:11px;box-shadow:var(--shadow-lg);z-index:200;display:flex;align-items:center;gap:11px;font-weight:500;
  animation:toastin .3s ease;}
@keyframes toastin{from{opacity:0;transform:transl(-50%,14px);}to{opacity:1;}}

/* mobile menu */
.mob-menu{display:none;}

/* ============ Responsive ============ */
@media(max-width:1080px){
  .cat-grid{grid-template-columns:repeat(3,1fr);}
  .sol-grid,.prod-grid{grid-template-columns:repeat(2,1fr);}
  .ftr-grid{grid-template-columns:1fr 1fr 1fr;}
  .hero .wrap{grid-template-columns:1fr;}
  .hero-art{height:280px;}
  .authpage{grid-template-columns:1fr;}
  .auth-aside{display:none;}
  .tile-grid{grid-template-columns:repeat(3,1fr);}
  .hero2 h1{font-size:46px;}
}
@media(max-width:860px){
  .wrap{padding:0 18px;}
  .nav{display:none;}
  .burger{display:flex;}
  .hdr-top{display:none;}
  .catalog{grid-template-columns:1fr;}
  .side{position:static;display:none;}
  .side.open{display:block;}
  .summary{position:static;margin-top:20px;}
  .hero h1{font-size:42px;}
  .section-head h2{font-size:32px;}
  .section{padding:40px 0;}
  .bookbar .wrap{flex-direction:column;}
  .stepper{flex-wrap:wrap;gap:10px;}
  .step .tx{display:none;}
  .step{flex:none;}
  .step .bar{width:24px;flex:none;}
  .mob-menu.open{display:block;position:fixed;inset:0;top:0;background:var(--navy);z-index:100;padding:20px;overflow:auto;}
  .hero2 h1{font-size:38px;}
  .hero2 .sub{font-size:17px;}
  .hsearch{flex-direction:column;gap:4px;}
  .hsearch .grp{padding:11px 14px;}
  .hsearch .grp + .grp{border-left:none;border-top:1px solid var(--line);}
  .hsearch .go{width:100%;}
  .tile-grid{grid-template-columns:repeat(2,1fr);}
  .jobsite-bar .chg{margin-left:0;}
  .rail-btn{display:none;}
  .promo h2{font-size:26px;}
  .promo .ct{padding:26px 24px;}
}
@media(max-width:560px){
  .tile-grid{grid-template-columns:1fr 1fr;}
  .hero2 .wrap{padding:40px 18px 0;}
  .cat-grid{grid-template-columns:repeat(2,1fr);}
  .sol-grid,.prod-grid{grid-template-columns:1fr;}
  .ftr-grid{grid-template-columns:1fr 1fr;}
  .list-row{grid-template-columns:80px 1fr;}
  .list-actions{grid-column:1/-1;width:100%;flex-direction:row;}
  .cart-item{grid-template-columns:70px 1fr;}
  .spec{grid-template-columns:1fr;}
  .page{padding:22px 0 48px;}
}

/* ====== Map picker modal ====== */
.modal-ov{position:fixed;inset:0;background:rgba(7,18,36,.72);z-index:300;
  display:flex;align-items:center;justify-content:center;padding:24px;animation:fadein .2s ease;}
@keyframes fadein{from{opacity:0;}to{opacity:1;}}
.modal{background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:920px;max-height:92vh;
  display:flex;flex-direction:column;overflow:hidden;animation:popin .22s ease;}
@keyframes popin{from{opacity:0;transform:translateY(14px) scale(.98);}to{opacity:1;transform:none;}}
.modal-head{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--line);}
.modal-head h3{font-size:20px;color:var(--navy);}
.modal-head .x{margin-left:auto;width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--slate);}
.modal-head .x:hover{background:var(--line-2);color:var(--ink);}
.map-search{display:flex;gap:9px;align-items:center;background:#fff;border:1.5px solid var(--line);border-radius:10px;
  padding:10px 13px;margin:16px 22px 0;box-shadow:var(--shadow-sm);}
.map-search input{border:none;outline:none;width:100%;font-size:15px;}
.map-presets{display:flex;gap:8px;flex-wrap:wrap;padding:12px 22px 4px;}
.map-presets .chip{font-size:13px;color:var(--slate);border:1px solid var(--line);border-radius:100px;padding:6px 13px;cursor:pointer;background:#fff;}
.map-presets .chip:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-soft);}

.map-canvas{position:relative;height:380px;margin:14px 22px 0;border-radius:12px;overflow:hidden;cursor:crosshair;
  border:1px solid var(--line);background:#e7edf0;}
.map-canvas .tiles{position:absolute;inset:-40px;transition:transform .05s linear;}
/* roads + blocks drawn with gradients */
.map-bg{position:absolute;inset:0;
  background:
    /* parks */
    radial-gradient(circle at 18% 72%, #cfe6c8 0 70px, transparent 72px),
    radial-gradient(circle at 82% 24%, #cfe6c8 0 90px, transparent 92px),
    /* water */
    linear-gradient(115deg, transparent 0 60%, #bcdcef 60.4% 67%, transparent 67.4%),
    /* minor grid */
    repeating-linear-gradient(0deg,#dfe7ec 0 1px, transparent 1px 64px),
    repeating-linear-gradient(90deg,#dfe7ec 0 1px, transparent 1px 64px),
    #eef2f4;}
.map-roads{position:absolute;inset:0;
  background:
    repeating-linear-gradient(0deg,#fff 0 7px, transparent 7px 190px),
    repeating-linear-gradient(90deg,#fff 0 7px, transparent 7px 230px);}
.map-roads.main{background:
    linear-gradient(0deg,transparent 38%, #ffe08a 38% calc(38% + 11px), transparent calc(38% + 11px)),
    linear-gradient(90deg,transparent 60%, #ffe08a 60% calc(60% + 11px), transparent calc(60% + 11px));}
.map-lbl{position:absolute;font-size:11px;color:#7c8a99;font-weight:600;white-space:nowrap;}
.map-pin{position:absolute;transform:translate(-50%,-100%);z-index:5;pointer-events:none;
  animation:drop .3s cubic-bezier(.2,1.2,.4,1);}
@keyframes drop{0%{transform:translate(-50%,-160%);opacity:0;}100%{transform:translate(-50%,-100%);opacity:1;}}
.map-pin .pulse{position:absolute;left:50%;bottom:-4px;width:22px;height:8px;transform:translateX(-50%);
  background:rgba(30,80,230,.28);border-radius:50%;filter:blur(1px);}
.map-hint{position:absolute;left:50%;top:14px;transform:translateX(-50%);background:rgba(255,255,255,.94);
  border:1px solid var(--line);border-radius:100px;padding:7px 16px;font-size:13px;color:var(--slate);font-weight:600;
  box-shadow:var(--shadow-sm);pointer-events:none;display:flex;align-items:center;gap:7px;}
.map-zoom{position:absolute;right:12px;bottom:12px;display:flex;flex-direction:column;border-radius:9px;overflow:hidden;
  box-shadow:var(--shadow);background:#fff;}
.map-zoom button{width:38px;height:38px;font-size:20px;color:var(--ink);border-bottom:1px solid var(--line);}
.map-zoom button:last-child{border-bottom:none;}
.map-zoom button:hover{background:var(--line-2);}
.map-coord{position:absolute;left:12px;bottom:12px;background:rgba(11,31,58,.86);color:#fff;font-size:12px;
  font-family:"IBM Plex Mono",monospace;padding:6px 11px;border-radius:7px;display:flex;align-items:center;gap:7px;}

.modal-foot{display:flex;align-items:center;gap:14px;padding:18px 22px;border-top:1px solid var(--line);margin-top:16px;flex-wrap:wrap;}
.modal-foot .sel{flex:1;min-width:200px;}
.modal-foot .sel .lbl{font-size:12px;color:var(--slate-2);font-weight:700;letter-spacing:.04em;text-transform:uppercase;}
.modal-foot .sel .val{font-size:15px;color:var(--ink);font-weight:600;margin-top:2px;}
.modal-foot .sel .val.empty{color:var(--slate-2);font-weight:400;}

@media(max-width:560px){
  .map-canvas{height:300px;}
  .modal-head h3{font-size:17px;}
  .modal-foot{flex-direction:column;align-items:stretch;}
  .modal-foot .btn{width:100%;}
}

/* ============ Admin Console ============ */
.admin-shell{display:flex;min-height:100vh;background:var(--bg);}
.admin-side{width:248px;flex:none;background:var(--navy);color:#fff;display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;}
.admin-brand{display:flex;align-items:center;gap:11px;padding:22px 20px;border-bottom:1px solid rgba(255,255,255,.08);}
.admin-brand b{font-family:"Anuphan",sans-serif;font-size:18px;display:block;line-height:1.1;}
.admin-brand small{color:#8ba0c0;font-size:11.5px;letter-spacing:.06em;}
.admin-nav{display:flex;flex-direction:column;gap:4px;padding:16px 12px;flex:1;}
.admin-nav button{display:flex;align-items:center;gap:11px;padding:12px 14px;border-radius:9px;color:#b9c6da;
  font-size:14.5px;font-weight:600;text-align:left;transition:.13s;}
.admin-nav button:hover{background:rgba(255,255,255,.06);color:#fff;}
.admin-nav button.on{background:var(--blue);color:#fff;}
.admin-side-foot{padding:16px 12px;border-top:1px solid rgba(255,255,255,.08);}
.admin-side-foot button{display:flex;align-items:center;gap:8px;color:#b9c6da;font-size:14px;font-weight:600;padding:10px 14px;width:100%;border-radius:8px;}
.admin-side-foot button:hover{background:rgba(255,255,255,.06);color:#fff;}

.admin-main{flex:1;min-width:0;height:100vh;overflow-y:auto;}
.admin-top{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;
  padding:30px 36px 22px;background:#fff;border-bottom:1px solid var(--line);}
.admin-crumb{font-size:12.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--slate-2);}
.admin-top h1{font-size:30px;color:var(--navy);margin:7px 0 4px;}
.admin-top p{color:var(--slate);font-size:14.5px;}
.admin-user{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:600;color:var(--ink);
  background:var(--bg);border:1px solid var(--line);border-radius:30px;padding:6px 14px 6px 6px;}
.admin-user .avatar{width:30px;height:30px;border-radius:50%;background:var(--blue);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-family:"Anuphan",sans-serif;}
.admin-body{padding:28px 36px 60px;}

/* stat cards */
.astat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.astat{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;display:flex;align-items:center;gap:15px;box-shadow:var(--shadow-sm);}
.astat-ic{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex:none;}
.astat.blue .astat-ic{background:var(--blue-soft);color:var(--blue);}
.astat.green .astat-ic{background:var(--green-soft);color:var(--green);}
.astat.amber .astat-ic{background:var(--amber-soft);color:var(--amber);}
.astat.purple .astat-ic{background:#efe9fd;color:#6d3fd6;}
.astat-v{font-family:"Anuphan",sans-serif;font-size:26px;font-weight:700;color:var(--navy);line-height:1;}
.astat-l{font-size:13.5px;color:var(--slate);margin-top:4px;}

/* cards */
.acard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;box-shadow:var(--shadow-sm);}
.acard.nopad{padding:0;overflow:hidden;}
.acard-h{display:flex;align-items:center;gap:9px;font-family:"Anuphan",sans-serif;font-weight:700;font-size:17px;color:var(--navy);margin-bottom:16px;}
.acard-h.sm{font-size:14px;margin-bottom:12px;color:var(--slate);text-transform:uppercase;letter-spacing:.05em;}
.acard-h.between{justify-content:space-between;}
.acard-h svg{color:var(--blue);}

/* category bars */
.cat-bars{display:grid;grid-template-columns:1fr 1fr;gap:14px 30px;}
.cat-bar{cursor:pointer;}
.cb-top{display:flex;justify-content:space-between;font-size:14px;margin-bottom:6px;}
.cb-top b{font-family:"Anuphan",sans-serif;color:var(--navy);}
.cb-track{height:8px;background:var(--line-2);border-radius:5px;overflow:hidden;}
.cb-fill{height:100%;background:var(--blue);border-radius:5px;transition:width .4s;}
.cat-bar:hover .cb-fill{background:var(--blue-dark);}

/* tables */
.atable{width:100%;border-collapse:collapse;font-size:14px;}
.atable th{text-align:left;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--slate-2);padding:11px 14px;border-bottom:1px solid var(--line);}
.atable td{padding:13px 14px;border-bottom:1px solid var(--line-2);vertical-align:middle;}
.atable.big td{padding:14px;}
.atable tr:last-child td{border-bottom:none;}
.atable tbody tr:hover{background:var(--bg);}
.atable b{font-weight:600;color:var(--ink);}
.td-sub{font-size:12.5px;color:var(--slate-2);font-family:"IBM Plex Mono",monospace;margin-top:2px;}
.atable-foot{padding:14px 4px;font-size:13px;color:var(--slate);}

.spill{display:inline-flex;align-items:center;font-size:12.5px;font-weight:600;padding:3px 11px;border-radius:20px;white-space:nowrap;}
.spill.ok{background:var(--green-soft);color:var(--green);}
.spill.warn{background:var(--amber-soft);color:#9a6c08;}
.spill.off{background:var(--line-2);color:var(--slate);}
.seo-dot{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--line-2);color:var(--slate-2);font-size:13px;}
.seo-dot.ok{background:var(--green-soft);color:var(--green);}
.row-act{display:flex;gap:6px;}
.row-act button{width:32px;height:32px;border-radius:8px;border:1px solid var(--line);color:var(--slate);display:flex;align-items:center;justify-content:center;transition:.13s;}
.row-act button:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-soft);}
.row-act button.del:hover{border-color:var(--red);color:var(--red);background:#fdecec;}

/* tools row */
.atools{display:flex;gap:12px;margin-bottom:18px;flex-wrap:wrap;}
.asearch{flex:1;min-width:220px;display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid var(--line);border-radius:9px;padding:0 14px;height:46px;}
.asearch svg{color:var(--slate-2);}
.asearch input{flex:1;border:none;outline:none;background:none;font-size:15px;}
.asel{height:46px;min-width:180px;}

/* form */
.inp{width:100%;border:1.5px solid var(--line);border-radius:9px;padding:11px 13px;font-size:15px;background:#fff;color:var(--ink);transition:.13s;}
.inp:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft);}
.inp.err{border-color:var(--red);box-shadow:0 0 0 3px #fdecec;}
select.inp{cursor:pointer;}
textarea.inp{resize:vertical;line-height:1.5;font-family:inherit;}
.aform-grid{display:grid;grid-template-columns:1fr 360px;gap:22px;align-items:start;}
.acol{display:flex;flex-direction:column;gap:18px;}
.afield{display:flex;flex-direction:column;gap:6px;}
.afield.full{grid-column:1/-1;}
.alabel{font-size:13px;font-weight:600;color:var(--ink);display:flex;justify-content:space-between;align-items:center;}
.alabel .cnt{font-style:normal;font-size:12px;color:var(--slate-2);font-weight:500;}
.alabel .cnt.over{color:var(--red);}
.ahint{font-size:12px;color:var(--slate-2);}
.agrid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.agrid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;}
.acheck{display:flex;align-items:center;gap:9px;margin-top:14px;font-size:14px;color:var(--ink);cursor:pointer;}
.acheck input{width:17px;height:17px;accent-color:var(--blue);}
.slug-row{display:flex;align-items:center;gap:0;border:1.5px solid var(--line);border-radius:9px;overflow:hidden;}
.slug-row span{padding:11px 12px;background:var(--bg);color:var(--slate);font-size:13.5px;font-family:"IBM Plex Mono",monospace;white-space:nowrap;border-right:1px solid var(--line);}
.slug-row .inp{border:none;border-radius:0;}
.slug-row .inp:focus{box-shadow:none;}

/* keyword chips */
.kw-box{display:flex;flex-wrap:wrap;gap:8px;border:1.5px solid var(--line);border-radius:9px;padding:9px 11px;background:#fff;min-height:46px;align-items:center;}
.kw-box:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft);}
.kw-chip{display:inline-flex;align-items:center;gap:6px;background:var(--blue-soft);color:var(--blue-dark);font-size:13.5px;font-weight:600;padding:5px 6px 5px 11px;border-radius:7px;}
.kw-chip button{display:flex;align-items:center;color:var(--blue);opacity:.7;}
.kw-chip button:hover{opacity:1;}
.kw-input{flex:1;min-width:160px;border:none;outline:none;font-size:14.5px;background:none;}

/* image uploader */
.img-up{display:flex;flex-direction:column;gap:12px;}
.img-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.img-thumb{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:4/3;border:1.5px solid var(--line);background:#f3f6fa;}
.img-thumb.main{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue-soft);}
.img-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.img-badge{position:absolute;left:7px;top:7px;background:var(--blue);color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;}
.img-acts{position:absolute;right:6px;top:6px;display:flex;gap:5px;}
.img-acts button{width:27px;height:27px;border-radius:7px;background:rgba(255,255,255,.94);color:var(--slate);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:.13s;}
.img-acts button:hover{background:#fff;color:var(--ink);}
.img-acts button.del:hover{background:var(--red);color:#fff;}
.img-drop{border:2px dashed var(--line-2);border-radius:11px;padding:24px 16px;text-align:center;cursor:pointer;
  color:var(--slate);transition:.15s;display:flex;flex-direction:column;align-items:center;gap:7px;background:#fafbfd;}
.img-drop:hover,.img-drop.on{border-color:var(--blue);background:var(--blue-soft);color:var(--blue-dark);}
.img-drop svg{color:var(--slate-2);}
.img-drop:hover svg,.img-drop.on svg{color:var(--blue);}
.img-drop-t{font-size:14.5px;}
.img-drop-t b{color:var(--blue);}
.img-drop-s{font-size:12.5px;color:var(--slate-2);}

/* SERP preview */
.aside-col .sticky{position:sticky;top:24px;}
.serp{border:1px solid var(--line);border-radius:12px;padding:16px;background:#fff;}
.serp-head{display:flex;align-items:center;gap:11px;margin-bottom:11px;}
.serp-fav{width:28px;height:28px;border-radius:50%;background:var(--navy);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:"Anuphan",sans-serif;}
.serp-site{font-size:13px;color:#202124;font-weight:500;line-height:1.2;}
.serp-url{font-size:12px;color:#5f6368;line-height:1.3;}
.serp-url b{font-weight:500;color:#5f6368;}
.serp-title{color:#1a0dab;font-size:18px;line-height:1.3;font-family:"Anuphan",sans-serif;margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;}
.serp-desc{color:#4d5156;font-size:13.5px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

/* mini product preview */
.prev-card{border:1px solid var(--line);border-radius:12px;overflow:hidden;}
.prev-ph{height:120px;background:repeating-linear-gradient(45deg,#eef1f6,#eef1f6 10px,#e7ebf2 10px,#e7ebf2 20px);position:relative;}
.prev-ph::after{content:attr(data-label);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--slate-2);font-size:13px;}
.prev-body{padding:13px 15px;}
.prev-cat{font-size:11.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--blue);}
.prev-name{font-family:"Anuphan",sans-serif;font-weight:600;font-size:16px;color:var(--navy);margin:3px 0;}
.prev-code{font-size:12px;font-family:"IBM Plex Mono",monospace;color:var(--slate-2);}
.prev-rate{margin-top:9px;font-size:14px;color:var(--slate);}
.prev-rate b{color:var(--navy);font-family:"Anuphan",sans-serif;font-size:17px;}
.prev-kw{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px;}
.prev-kw span{font-size:12px;color:var(--slate);background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:3px 8px;}
.seo-tag{font-size:12px;font-weight:600;color:var(--blue);background:var(--blue-soft);border-radius:6px;padding:3px 8px;white-space:nowrap;}

.aform-foot{display:flex;justify-content:flex-end;gap:12px;margin-top:22px;position:sticky;bottom:0;
  background:linear-gradient(to top,var(--bg) 60%,transparent);padding:18px 0 4px;}

@media(max-width:1080px){
  .aform-grid{grid-template-columns:1fr;}
  .aside-col .sticky{position:static;}
  .astat-grid{grid-template-columns:1fr 1fr;}
  .cat-bars{grid-template-columns:1fr;}
}
@media(max-width:820px){
  .admin-side{position:fixed;left:0;top:0;z-index:50;width:72px;}
  .admin-brand div,.admin-nav button span,.admin-side-foot button span{display:none;}
  .admin-nav button{justify-content:center;}
  .admin-main{margin-left:72px;}
  .admin-top,.admin-body{padding-left:20px;padding-right:20px;}
  .agrid3,.agrid2{grid-template-columns:1fr;}
  .atable.big{font-size:13px;}
}

/* ====== Customer directory + credit control ====== */
.cust-cell{display:flex;align-items:center;gap:12px;}
.cust-ava{flex:none;width:38px;height:38px;border-radius:10px;background:var(--blue-soft);color:var(--blue-dark);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;font-family:"Anuphan",sans-serif;}
.cust-ava.lg{width:48px;height:48px;border-radius:12px;font-size:20px;}

.cbar{display:flex;align-items:center;gap:9px;}
.cbar-track{flex:1;height:7px;border-radius:99px;background:var(--line-2);overflow:hidden;min-width:60px;}
.cbar-fill{height:100%;border-radius:99px;transition:width .25s;}
.cbar-fill.ok{background:var(--green);}
.cbar-fill.warn{background:var(--amber);}
.cbar-fill.danger{background:var(--red);}
.cbar-pct{font-size:12.5px;font-weight:600;color:var(--slate);font-family:"Anuphan",sans-serif;min-width:30px;text-align:right;}

.cust-modal{max-width:560px;}
.cmodal-body{padding:20px 22px 4px;overflow-y:auto;}
.credit-snap{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:14px;}
.csnap{background:var(--bg);border:1px solid var(--line);border-radius:11px;padding:13px 14px;}
.csnap-l{font-size:12.5px;color:var(--slate);margin-bottom:6px;}
.csnap-v{font-family:"Anuphan",sans-serif;font-size:20px;font-weight:700;color:var(--navy);line-height:1;}
.csnap-v.hi{color:var(--green);}

.seg.seg-line.sm{margin-bottom:0;}
.seg.seg-line.sm button{display:flex;align-items:center;justify-content:center;gap:7px;padding:11px;font-size:14.5px;}
.seg.seg-line.sm button.active{color:var(--blue);}

.amt-row{display:flex;gap:14px;margin:16px 0 4px;flex-wrap:wrap;}
.amt-input{flex:1;min-width:180px;display:flex;align-items:center;gap:8px;border:1.5px solid var(--line);border-radius:11px;
  padding:0 16px;height:60px;background:#fff;transition:.13s;}
.amt-input:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft);}
.amt-sign{font-family:"Anuphan",sans-serif;font-size:22px;font-weight:700;color:var(--slate-2);}
.amt-input input{flex:1;border:none;outline:none;background:none;font-family:"Anuphan",sans-serif;font-size:26px;font-weight:700;color:var(--navy);min-width:0;}
.amt-presets{display:grid;grid-template-columns:1fr 1fr;gap:7px;}
.amt-presets button{border:1.5px solid var(--line);border-radius:8px;padding:7px 12px;font-size:13px;font-weight:600;color:var(--slate);background:#fff;transition:.13s;white-space:nowrap;}
.amt-presets button:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-soft);}

.amt-preview{margin-top:14px;background:var(--blue-soft);border:1px solid #cdddfb;border-radius:10px;padding:12px 14px;
  font-size:14px;color:var(--blue-dark);display:flex;align-items:center;gap:8px;}
.amt-preview b{font-family:"Anuphan",sans-serif;}
.amt-preview.bad{background:#fdecec;border-color:#f6c9c9;color:#a52828;}

.ledger{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:11px;overflow:hidden;}
.ledger-row{display:flex;align-items:center;gap:13px;padding:12px 14px;border-bottom:1px solid var(--line-2);}
.ledger-row:last-child{border-bottom:none;}
.ledger-delta{flex:none;font-family:"Anuphan",sans-serif;font-weight:700;font-size:15px;min-width:92px;}
.ledger-delta.up{color:var(--green);}
.ledger-delta.down{color:var(--red);}
.ledger-mid{min-width:0;}
.ledger-note{font-size:14px;color:var(--ink);line-height:1.35;}
.ledger-meta{font-size:12px;color:var(--slate-2);margin-top:3px;}

@media(max-width:560px){
  .credit-snap{grid-template-columns:1fr;}
  .csnap{display:flex;align-items:baseline;justify-content:space-between;}
  .csnap-l{margin-bottom:0;}
  .amt-presets{grid-template-columns:repeat(4,1fr);}
}
