/* =====================================================
   70mai Booking — Shared light theme
   ===================================================== */
:root{
  --brand:        #ff5b1f;     /* 70mai orange */
  --brand-2:      #ff7a3d;
  --brand-soft:   #fff4ed;
  --brand-line:   #ffd9c2;
  --ink:          #0a0a0a;
  --ink-2:        #1f1f1f;
  --ink-3:        #404040;
  --ink-4:        #6b6b6b;
  --muted:        #8a8a8a;
  --line:         #eaeaea;
  --line-2:       #f4f4f4;
  --line-3:       #f9f9f9;
  --bg:           #fafafa;
  --surface:      #ffffff;
  --surface-2:    #fafafa;
  --ok:           #16a34a;
  --ok-soft:      #ecfdf3;
  --warn:         #b45309;
  --warn-soft:    #fff7e6;
  --danger:       #dc2626;
  --danger-soft:  #fef2f2;
  --info:         #2563eb;
  --info-soft:    #eff6ff;
  --shadow-xs:    0 1px 0 rgba(0,0,0,.04);
  --shadow-sm:    0 1px 2px rgba(0,0,0,.04), 0 1px 1px rgba(0,0,0,.02);
  --shadow:       0 1px 2px rgba(0,0,0,.04), 0 4px 16px rgba(0,0,0,.05);
  --shadow-lg:    0 8px 24px rgba(0,0,0,.06), 0 24px 64px rgba(0,0,0,.10);
  --shadow-pop:   0 8px 32px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.04);
  --radius-sm:    8px;
  --radius:       14px;
  --radius-lg:    20px;
  --radius-xl:    28px;
  --container:    1180px;
  --header-h:     68px;
  --transition:   .22s cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'IBM Plex Sans Thai','Sarabun','Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--bg);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit}
input,select,textarea{font-family:inherit}

/* =========== Header =========== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(150%) blur(10px);
  border-bottom:1px solid var(--line);
}
.site-header .inner{
  max-width:var(--container);margin:0 auto;
  height:var(--header-h);
  padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;color:var(--ink)}
.brand-logo{
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  display:grid;place-items:center;color:#fff;font-weight:900;font-size:13px;
  box-shadow:var(--shadow-sm);
}
.brand-logo-img{
  height:30px;width:auto;display:block;
  /* keep the original mark in pure black on light bg */
}
.brand-tag{
  font-size:13px;font-weight:600;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;
  padding:4px 10px;background:var(--line-2);border-radius:999px;
}
.admin-side .brand-logo-img{height:26px}
.admin-side .brand-tag{background:var(--brand-soft);color:var(--brand)}
.nav{display:flex;align-items:center;gap:6px}
.nav a{
  padding:8px 14px;border-radius:10px;color:var(--ink-2);font-weight:600;font-size:14px;
  transition:var(--transition);display:inline-flex;align-items:center;gap:6px;
}
.nav a:hover{background:var(--line-2);color:var(--ink)}
.nav a.active{background:var(--ink);color:#fff}
.nav .ghost{
  color:var(--ink);background:transparent;border:1px solid var(--line);
}
.nav .ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.nav .nav-external{color:var(--brand-2)}
.nav .nav-external:hover{background:var(--brand-soft);color:var(--brand)}
.nav .nav-external svg{opacity:.85}

/* Mobile hamburger toggle (hidden on desktop) */
.nav-toggle{
  display:none;background:transparent;border:none;cursor:pointer;
  width:40px;height:40px;border-radius:10px;color:var(--ink);
  align-items:center;justify-content:center;
}
.nav-toggle:hover{background:var(--line-2)}
.nav-toggle .i-close{display:none}
.nav-toggle.open .i-menu{display:none}
.nav-toggle.open .i-close{display:block}

/* =========== Hero =========== */
.hero{
  position:relative;overflow:hidden;
  padding:104px 24px 80px;
  background:
    radial-gradient(900px 280px at 50% -120px, rgba(255,91,31,.14), transparent 60%),
    linear-gradient(180deg, #fff 0%, var(--bg) 100%);
  border-bottom:1px solid var(--line);
  text-align:center;
}
.hero .inner{max-width:820px;margin:0 auto;position:relative;z-index:2}

/* tech grid pattern (faded near edges) */
.hero-grid-bg{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(to right, rgba(10,10,10,.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(10,10,10,.045) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(900px 460px at 50% 38%, #000 25%, transparent 80%);
          mask-image: radial-gradient(900px 460px at 50% 38%, #000 25%, transparent 80%);
}

/* === Scroll-Expand hero (light mode, white background) === */
.hero-expand{
  position:relative;
  overflow:hidden;
  background:#ffffff;
}
.hero-expand-bg{
  position:absolute; inset:0; z-index:0;
  pointer-events:none;
}
.hero-expand-bg img{
  width:100%; height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  opacity:.85;
}
.hero-expand-bg::after{
  content:""; position:absolute; inset:0;
  background:
    /* slight orange wash from top */
    radial-gradient(ellipse 80% 40% at 50% 0%, rgba(255,91,31,.08), transparent 60%),
    /* fade to white at bottom for clean section transition */
    linear-gradient(180deg, transparent 0%, transparent 55%, rgba(255,255,255,.4) 80%, #ffffff 100%);
  pointer-events:none;
}
/* fallback when bg image fails to load */
.hero-expand-bg-fallback{
  position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(ellipse at 50% 30%, rgba(255,91,31,.10), transparent 60%),
    #ffffff;
}

.hero-expand-stage{
  position:relative; z-index:1;
  height:100dvh;
  display:flex; align-items:center; justify-content:center;
}

.hero-expand-media{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%, -50%);
  width:300px; height:400px;
  max-width:95vw; max-height:85vh;
  border-radius:20px;
  overflow:hidden;
  box-shadow:
    0 24px 80px rgba(255,91,31,.18),
    0 12px 40px rgba(0,0,0,.18),
    0 0 0 1px rgba(0,0,0,.06);
  background:#0a0a0a;
  will-change:width, height;
}
.hero-expand-media .hero-media-el{
  width:100%; height:100%;
  object-fit:cover; display:block;
  pointer-events:none;
}
.hero-media-overlay{
  position:absolute; inset:0;
  background:rgba(0,0,0,calc(0.45 - var(--p, 0) * 0.35));
  pointer-events:none;
}

/* Title — bold black with orange accent (no mix-blend) */
.hero-expand-title-wrap{
  position:relative; z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  pointer-events:none;
  text-align:center; padding:0 16px;
}
/* Eyebrow: small uppercase mono pill with pulsing brand dot */
.title-eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:'JetBrains Mono', ui-monospace, monospace;
  font-size:11px; font-weight:700;
  letter-spacing:.34em; text-transform:uppercase;
  color:var(--ink);
  padding:7px 16px 7px 14px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(10,10,10,.08);
  border-radius:999px;
  margin-bottom:14px;
  backdrop-filter:blur(8px);
  box-shadow:0 4px 20px rgba(0,0,0,.10), inset 0 1px 0 rgba(255,255,255,.6);
}
.title-eyebrow-dot{
  width:7px; height:7px; border-radius:50%;
  background:var(--brand);
  box-shadow:0 0 0 3px rgba(255,91,31,.22);
  animation:pulse 2.4s ease-in-out infinite;
}

/* Hint chip: white glass, monospace */
.hero-scroll-hint{
  background:rgba(255,255,255,.92) !important;
  border-color:rgba(10,10,10,.08) !important;
  color:var(--ink) !important;
  backdrop-filter:blur(8px);
  box-shadow:0 4px 20px rgba(0,0,0,.10), inset 0 1px 0 rgba(255,255,255,.6);
  font-family:'JetBrains Mono', ui-monospace, monospace;
  font-size:11.5px;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding:9px 18px !important;
  margin-top:24px !important;
}

/* Title — editorial stack: thin pretitle + huge brand */
.hero-expand-title{
  display:flex; flex-direction:column; align-items:center;
  gap:4px; margin:0;
  line-height:1;
  /* glass treatment applied to .title-pre only — brand is solid */
  filter:
    drop-shadow(0 6px 24px rgba(0,0,0,.32))
    drop-shadow(0 2px 6px rgba(0,0,0,.22));
}

/* Pre-title — thinner, wider, calmer */
.hero-expand-title .title-pre{
  display:inline-block;
  font-family:'Inter','IBM Plex Sans Thai',sans-serif;
  font-size:clamp(18px, 2.6vw, 32px);
  font-weight:500;
  letter-spacing:.04em;
  color:#fff;
  text-shadow:
    0 1px 0 rgba(255,255,255,.45),
    0 2px 8px rgba(0,0,0,.35);
}

/* Brand — massive display, gradient orange italic */
.hero-expand-title .title-brand{
  display:inline-block;
  font-size:clamp(56px, 12vw, 160px);
  font-weight:900;
  letter-spacing:-.05em;
  line-height:1;
}
.hero-expand-title .accent{
  display:inline-block;
  font-style:italic;
  background:linear-gradient(135deg,
    #ffb38a 0%,
    var(--brand-2) 25%,
    var(--brand) 50%,
    #ff4500 75%,
    var(--brand) 100%);
  background-size:250% 100%;
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
  -webkit-text-stroke:0;
  animation:titleGradientShift 5s ease-in-out infinite;
}
@keyframes titleGradientShift{
  0%,100% { background-position: 0% 50% }
  50%     { background-position: 100% 50% }
}

/* Post-tagline — italic with dashes left/right */
.title-post{
  display:inline-flex; align-items:center; gap:14px;
  margin-top:6px;
  font-family:'Inter','IBM Plex Sans Thai',sans-serif;
  font-size:clamp(15px, 1.8vw, 22px);
  font-weight:600;
  font-style:italic;
  letter-spacing:.02em;
  color:#fff;
  text-shadow:
    0 1px 0 rgba(255,255,255,.5),
    0 2px 8px rgba(0,0,0,.35);
}
.title-post-dash{
  display:inline-block;
  width:36px; height:2px;
  background:linear-gradient(90deg, transparent, var(--brand) 50%, transparent);
  border-radius:2px;
}
.hero-word{
  display:block;
  will-change:transform;
  transition:transform .05s linear;
}
.hero-scroll-hint{
  display:inline-flex; align-items:center; gap:6px;
  margin:18px 0 0;
  padding:8px 16px;
  background:rgba(10,10,10,.06);
  border:1px solid rgba(10,10,10,.10);
  backdrop-filter:blur(8px);
  border-radius:999px;
  color:var(--ink-2);
  font-size:13px; font-weight:600;
  animation:scrollHintBounce 1.6s ease-in-out infinite;
}
@keyframes scrollHintBounce{
  0%,100% { transform:translateY(0) }
  50%     { transform:translateY(4px) }
}

.hero-expand-content{
  position:relative; z-index:3;
  display:flex; flex-direction:column; align-items:center;
  gap:18px;
  padding:48px 24px 64px;
  text-align:center;
  background:linear-gradient(180deg, transparent, #fff 50%, var(--bg) 100%);
  opacity:0; transform:translateY(20px);
  transition:opacity .6s ease, transform .6s ease;
  pointer-events:none;
}
.hero-expand-content.show{
  opacity:1; transform:translateY(0);
  pointer-events:auto;
}
.hero-expand-lead{
  margin:0; font-size:16px; color:var(--ink-3);
  max-width:560px; line-height:1.55;
}

.hero-expand.reduced .hero-expand-stage{ height:auto; padding:48px 0 }
.hero-expand.reduced .hero-expand-media{ position:relative; transform:none; top:auto; left:auto; width:100%; max-width:560px; aspect-ratio:16/10; height:auto }
.hero-expand.reduced .hero-scroll-hint{ display:none }

@media (max-width:760px){
  .hero-expand-title{ font-size:clamp(28px, 9vw, 44px) }
  .hero-expand-title .title-pre{ font-size:clamp(14px, 4.4vw, 18px) }
  .hero-expand-title .title-brand{ font-size:clamp(48px, 17vw, 80px) }
  .title-post{ font-size:clamp(13px, 4vw, 16px); gap:8px }
  .title-post-dash{ width:24px }
  .title-eyebrow{ font-size:10.5px; letter-spacing:.25em }
  .hero-expand-content{ padding:32px 16px 48px }
}

/* === Lamp glow stage — soft radial gradient, no hard edges === */
.hero-lamp{ padding-top: 130px; }
.lamp-stage{
  position:absolute;
  inset:0; top:-20px;
  pointer-events:none;
  z-index:0;
  overflow:hidden;
}

/* Big soft aura — no edges, fades in every direction */
.lamp-aura{
  position:absolute;
  top:-30%; left:50%; transform:translateX(-50%);
  width:140%; height:140%;
  background:
    radial-gradient(ellipse 50% 38% at 50% 32%,
      rgba(255,91,31,.32) 0%,
      rgba(255,120,70,.20) 18%,
      rgba(255,150,100,.10) 38%,
      rgba(255,180,130,.04) 58%,
      transparent 78%);
  filter: blur(8px);
  opacity:0;
  animation: lampAura 1.4s .15s cubic-bezier(.2,.7,.2,1) forwards;
}

/* Concentrated highlight — bright orange center */
.lamp-glow{
  position:absolute;
  top:120px; left:50%; transform:translateX(-50%);
  width:46%; max-width:560px; height:170px;
  background:
    radial-gradient(ellipse 60% 60% at 50% 50%,
      rgba(255,200,160,.55) 0%,
      rgba(255,170,120,.32) 30%,
      rgba(255,140,90,.14) 55%,
      transparent 80%);
  filter: blur(28px);
  opacity:0;
  animation: lampGlow 1.5s .3s cubic-bezier(.2,.7,.2,1) forwards;
}

/* Subtle horizontal accent line under glow — feathered ends */
.lamp-line{
  position:absolute;
  top:212px; left:50%; transform:translateX(-50%) scaleX(.35);
  width:38%; max-width:520px; height:1.5px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(255,91,31,0) 8%,
    rgba(255,91,31,.35) 25%,
    var(--brand) 45%,
    var(--brand-2) 50%,
    var(--brand) 55%,
    rgba(255,91,31,.35) 75%,
    rgba(255,91,31,0) 92%,
    transparent 100%);
  box-shadow:
    0 0 12px rgba(255,91,31,.4),
    0 0 28px rgba(255,140,90,.2),
    0 -3px 24px rgba(255,170,120,.16);
  border-radius:2px;
  opacity:0;
  animation: lampLine 1.3s .45s cubic-bezier(.2,.7,.2,1) forwards;
}

@keyframes lampAura { from { opacity:0; transform:translateX(-50%) scale(.92) } to { opacity:1; transform:translateX(-50%) scale(1) } }
@keyframes lampGlow { from { opacity:0; transform:translateX(-50%) scale(.7) } to { opacity:1; transform:translateX(-50%) scale(1) } }
@keyframes lampLine { from { opacity:0; transform:translateX(-50%) scaleX(.2) } to { opacity:1; transform:translateX(-50%) scaleX(1) } }

@media (prefers-reduced-motion: reduce){
  .lamp-aura, .lamp-glow, .lamp-line{ animation: none; opacity: 1 }
}
@media (max-width: 760px){
  .hero-lamp{ padding-top: 90px }
  .lamp-glow{ top: 80px; height: 130px }
  .lamp-line{ top: 168px; width: 60%; max-width: 360px }
}

/* === Gooey morphing word (hero) === */
.hero-morph-line{
  /* block-level flex so it goes on its own line, but children share baseline */
  display:flex !important;
  align-items:baseline;
  justify-content:center;
  flex-wrap:nowrap;
  gap:.18em;
  font-size:inherit;
  line-height:inherit;
  font-weight:inherit;
}
.gooey-wrap{
  position:relative;
  display:inline-block;
  vertical-align: baseline;
  filter: url(#gooey-threshold);
  /* keep words horizontally centered without shifting tail */
  text-align:center;
}
/* invisible ghost = longest word, gives wrap its size */
.gooey-ghost{
  display:inline-block;
  visibility:hidden;
  pointer-events:none;
  font-weight:inherit;
  font-size:inherit;
  line-height:inherit;
  letter-spacing:inherit;
}
.gooey-word{
  position:absolute;
  top:0; left:0; right:0;
  white-space:nowrap;
  color: var(--brand);
  font-weight:inherit;
  font-size:inherit;
  line-height:inherit;
  letter-spacing:inherit;
  text-align:center;
}
.gooey-1{ opacity: 0; }
.gooey-2{ opacity: 1; }
.hero-tail{ color: var(--ink) }

.hero-grid{display:block}

/* eyebrow chip — mono tech feel */
.hero-chip{
  font-family:'JetBrains Mono', ui-monospace, monospace;
  letter-spacing:.04em;text-transform:uppercase;
  font-size:11.5px;padding:6px 14px;
}

/* title — split lines for stagger + generous Thai line-height */
.hero-title{
  font-size:64px;line-height:1.18;
  margin:14px 0 22px;font-weight:800;letter-spacing:-.025em;color:var(--ink);
}
.hero-title .hero-line{display:block}
.hero-title .accent{
  background:linear-gradient(120deg,var(--brand),var(--brand-2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  position:relative;display:inline-block;
}

.hero p{color:var(--ink-3);font-size:17.5px;margin:0 auto 28px;max-width:560px;line-height:1.6;text-align:center}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.chip-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:22px;justify-content:center}
.chip{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);
  color:var(--ink-2);font-weight:600;font-size:12.5px;
  transition:var(--transition);
}
.chip:hover{border-color:var(--ink-3);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.chip-dot{
  width:8px;height:8px;border-radius:50%;background:var(--ok);
  box-shadow:0 0 0 3px rgba(22,163,74,.18);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{0%,100%{box-shadow:0 0 0 3px rgba(22,163,74,.18)}50%{box-shadow:0 0 0 6px rgba(22,163,74,.05)}}

/* === entrance race-in animations (stagger) === */
@keyframes heroFadeUp { from { opacity:0; transform:translateY(28px) } to { opacity:1; transform:translateY(0) } }
@keyframes heroFadeIn { from { opacity:0 } to { opacity:1 } }

.hero .hero-chip                       { animation: heroFadeUp .7s .05s both cubic-bezier(.2,.7,.2,1) }
.hero-title .hero-line:nth-of-type(1)  { animation: heroFadeUp .9s .18s both cubic-bezier(.2,.7,.2,1) }
.hero-title .hero-line:nth-of-type(2)  { animation: heroFadeUp .9s .32s both cubic-bezier(.2,.7,.2,1) }
.hero p                                { animation: heroFadeUp .9s .48s both cubic-bezier(.2,.7,.2,1) }
.hero .hero-cta                        { animation: heroFadeUp .9s .62s both cubic-bezier(.2,.7,.2,1) }
.hero .chip-row                        { animation: heroFadeUp .9s .76s both cubic-bezier(.2,.7,.2,1) }
.hero-grid-bg                          { animation: heroFadeIn 1.6s .2s both }

@media (prefers-reduced-motion: reduce){
  .hero .hero-chip,.hero-title .hero-line,.hero p,.hero .hero-cta,.hero .chip-row,.hero-grid-bg{
    animation:none;opacity:1;transform:none
  }
}

.hero-card,.hero-bg-blob{display:none}

/* =========== Section / Cards =========== */
.section{padding:36px 24px}
.section .inner{max-width:var(--container);margin:0 auto}
.section-title{font-size:30px;font-weight:800;margin:0 0 8px;letter-spacing:-.025em;line-height:1.1}
.section-subtitle{color:var(--muted);margin:0 0 28px;font-size:15px;line-height:1.55}

.section-eyebrow{
  display:inline-flex;align-items:center;gap:8px;font-size:11.5px;font-weight:700;color:var(--brand);
  text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px;
  padding:5px 12px;background:var(--brand-soft);border:1px solid var(--brand-line);border-radius:999px;
}

.card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-xs);
  transition:var(--transition);
}
.card.flush{padding:0;overflow:hidden}
.card h3{margin:0 0 12px;font-size:16px;font-weight:800;letter-spacing:-.005em;color:var(--ink)}
.card-h{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.card-h h3{margin:0}
.card-h .icon-tile{width:32px;height:32px;border-radius:9px}

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

/* =========== Buttons =========== */
.btn{
  --h:46px;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:var(--h);padding:0 20px;border-radius:12px;border:1px solid transparent;
  font-weight:700;font-size:14.5px;cursor:pointer;
  transition:var(--transition);user-select:none;
}
.btn-primary{
  background:var(--ink);color:#fff;
  box-shadow:0 1px 0 rgba(0,0,0,.06), inset 0 1px 0 rgba(255,255,255,.08);
}
.btn-primary:hover{background:#000;box-shadow:0 6px 20px rgba(0,0,0,.18)}
.btn-primary:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}
.btn-brand{
  background:var(--brand);color:#fff;
  box-shadow:0 1px 0 rgba(0,0,0,.06), inset 0 1px 0 rgba(255,255,255,.18);
}
.btn-brand:hover{background:#ee4f17;box-shadow:0 8px 22px rgba(255,91,31,.28)}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{background:var(--line-2);border-color:var(--ink-3)}
.btn-outline{background:#fff;border-color:var(--brand);color:var(--brand)}
.btn-outline:hover{background:var(--brand-soft)}
.btn-danger{background:#fff;border-color:var(--danger);color:var(--danger)}
.btn-danger:hover{background:var(--danger-soft)}
.btn-sm{--h:36px;padding:0 14px;font-size:13.5px;border-radius:10px}
.btn-lg{--h:54px;padding:0 26px;font-size:15.5px;border-radius:14px}
.btn-block{width:100%}
.btn svg{width:16px;height:16px}
.btn-lg svg{width:18px;height:18px}

/* =========== Forms =========== */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field > label{font-weight:600;font-size:13.5px;color:var(--ink-2)}
.field .hint{font-size:12.5px;color:var(--muted)}
.input,.select,.textarea{
  width:100%;height:44px;padding:0 14px;border-radius:12px;background:#fff;
  border:1px solid var(--line);color:var(--ink);font-size:14.5px;
  transition:var(--transition);
}
.textarea{height:auto;min-height:96px;padding:12px 14px;resize:vertical}
.input:focus,.select:focus,.textarea:focus{
  outline:none;border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-soft);
}
.select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 20 20'><path fill='%236b7588' d='M5.5 7.5l4.5 4.5 4.5-4.5z'/></svg>");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;
}

.row{display:grid;gap:14px}
.row-2{grid-template-columns:1fr 1fr}
.row-3{grid-template-columns:1fr 1fr 1fr}
.row-4{grid-template-columns:repeat(4,1fr)}

/* segmented (radio cards) */
.segmented{display:grid;gap:10px}
.seg-2{grid-template-columns:1fr 1fr}
.seg-4{grid-template-columns:repeat(4,1fr)}
.seg-opt{
  position:relative;border:1.5px solid var(--line);background:#fff;
  border-radius:14px;padding:14px;cursor:pointer;
  transition:var(--transition);
}
.seg-opt:hover{border-color:var(--brand);background:var(--brand-soft)}
.seg-opt input{position:absolute;opacity:0;inset:0;cursor:pointer}
.seg-opt .seg-title{font-weight:700;font-size:14.5px;color:var(--ink)}
.seg-opt .seg-desc{font-size:12.5px;color:var(--muted);margin-top:2px}
.seg-opt input:checked ~ *{color:var(--ink)}
.seg-opt:has(input:checked){
  border-color:var(--brand);background:var(--brand-soft);
  box-shadow:0 0 0 3px rgba(255,91,31,.12);
}

/* slot grid */
.slots{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.slot{
  height:46px;border-radius:12px;border:1.5px solid var(--line);background:#fff;
  font-weight:700;color:var(--ink);cursor:pointer;transition:var(--transition);
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
}
.slot:hover:not(:disabled){border-color:var(--brand);color:var(--brand)}
.slot.selected{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;border-color:transparent}
.slot:disabled{opacity:.4;cursor:not-allowed;background:var(--line-2)}
.slot small{font-weight:500;font-size:11px;opacity:.7}

/* badges */
.badge{
  display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;
  font-weight:700;font-size:12px;
}
.badge-ok{background:var(--ok-soft);color:var(--ok)}
.badge-warn{background:var(--warn-soft);color:var(--warn)}
.badge-info{background:var(--info-soft);color:var(--info)}
.badge-danger{background:var(--danger-soft);color:var(--danger)}
.badge-mute{background:var(--line-2);color:var(--muted)}

/* =========== Service Type Switch =========== */
.service-switch{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  background:var(--line-2);padding:6px;border-radius:14px;margin-bottom:18px;
}
.service-switch button{
  height:48px;border:none;background:transparent;border-radius:10px;font-weight:700;color:var(--ink-2);
  cursor:pointer;transition:var(--transition);font-size:14.5px;
}
.service-switch button.active{background:#fff;color:var(--brand);box-shadow:var(--shadow-sm)}

/* =========== Map =========== */
.map-container{
  width:100%;height:380px;border-radius:14px;overflow:hidden;border:1px solid var(--line);
  background:linear-gradient(135deg,#eef2f7,#f7f8fb);
}
.map-info-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:12px}
.map-info-pill{
  display:inline-flex;align-items:center;gap:8px;padding:8px 14px;
  background:#fff;border:1px solid var(--line);border-radius:999px;
  font-size:13.5px;font-weight:600;
}

/* =========== Car cards (multi-car) =========== */
.car-card{
  border:1px solid var(--line);border-radius:18px;background:#fff;
  margin-bottom:16px;overflow:hidden;
}
.car-card-head{
  background:linear-gradient(135deg,#fff7f1,#fff);
  padding:14px 18px;border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
}
.car-card-head h4{margin:0;font-size:15.5px;display:flex;align-items:center;gap:10px}
.car-emoji{
  width:32px;height:32px;border-radius:10px;background:var(--brand-soft);
  display:grid;place-items:center;font-size:16px;
}
.car-card-body{padding:18px}

/* =========== Booking Center (lookup) =========== */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px}
.step{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;
  display:flex;gap:12px;align-items:flex-start;
}
.step .num{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;
  display:grid;place-items:center;font-weight:800;flex-shrink:0;
}
.step h4{margin:0 0 4px;font-size:14.5px}
.step p{margin:0;color:var(--muted);font-size:13px;line-height:1.5}

/* =========== Result block =========== */
.result{
  background:linear-gradient(135deg,#fff,#fff8f3);
  border:1px solid var(--line);border-radius:18px;padding:22px;
}
.result-head{
  display:flex;align-items:center;justify-content:space-between;
  padding-bottom:14px;border-bottom:1px dashed var(--line);margin-bottom:14px;flex-wrap:wrap;gap:10px;
}
.result-head .ref{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:18px;font-weight:800;
  background:var(--brand-soft);color:var(--brand);padding:6px 14px;border-radius:10px;letter-spacing:.06em;
}
.result-info{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.result-info .item{padding:10px 0}
.result-info .item .l{font-size:12px;color:var(--muted);font-weight:600}
.result-info .item .v{font-size:14.5px;font-weight:700;margin-top:2px}

/* =========== Modal =========== */
.modal-backdrop{
  position:fixed;inset:0;background:rgba(13,22,35,.45);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;z-index:100;padding:24px;
}
.modal-backdrop.show{display:flex}
.modal{
  background:#fff;border-radius:20px;max-width:560px;width:100%;
  max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);
  animation:modalIn .25s cubic-bezier(.2,.7,.2,1);
}
.modal-lg{max-width:840px}
@keyframes modalIn{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}
.modal-head{
  padding:18px 22px;border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
}
.modal-head h3{margin:0;font-size:17px}
.modal-body{padding:22px}
.modal-foot{padding:16px 22px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}
.modal-close{
  width:34px;height:34px;border-radius:10px;border:none;background:var(--line-2);
  cursor:pointer;color:var(--ink-2);font-size:18px;
}
.modal-close:hover{background:var(--danger-soft);color:var(--danger)}

/* =========== Drawer (right-side panel) =========== */
.drawer-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,0);
  display:flex;justify-content:flex-end;z-index:120;
  transition:background .24s ease;
}
.drawer-backdrop.open{background:rgba(0,0,0,.32);backdrop-filter:blur(2px)}
.drawer{
  background:#fff;height:100vh;display:flex;flex-direction:column;
  box-shadow:-12px 0 40px rgba(0,0,0,.14);
  transform:translateX(100%);
  transition:transform .26s cubic-bezier(.2,.7,.2,1);
  width:100%;
}
.drawer-md{max-width:560px}
.drawer-lg{max-width:760px}
.drawer-xl{max-width:1000px}
.drawer-backdrop.open .drawer{transform:translateX(0)}
.drawer-head{
  padding:18px 22px;border-bottom:1px solid var(--line);
  display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-shrink:0;
}
.drawer-head-text{min-width:0;flex:1}
.drawer-head h3{margin:0;font-size:18px;font-weight:800;color:var(--ink);letter-spacing:-.01em}
.drawer-sub{font-size:12.5px;color:var(--muted);margin-top:3px;font-weight:500}
.drawer-close{
  width:34px;height:34px;border-radius:10px;border:none;background:var(--line-2);
  cursor:pointer;color:var(--ink-2);font-size:20px;line-height:1;flex-shrink:0;
  transition:var(--transition);
}
.drawer-close:hover{background:var(--ink);color:#fff}
.drawer-body{padding:22px;overflow-y:auto;flex:1;background:var(--bg)}
.drawer-foot{
  padding:14px 22px;border-top:1px solid var(--line);background:#fff;
  display:flex;gap:10px;justify-content:flex-end;flex-shrink:0;flex-wrap:wrap;
}

/* sticky section heads inside drawer */
.drawer-section{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;margin-bottom:14px}
.drawer-section h4{margin:0 0 12px;font-size:14px;font-weight:800;color:var(--ink);text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;gap:8px}
.drawer-section h4 .ico{font-size:16px}

/* edit-mode car block */
.edit-car{
  border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:10px;
  background:var(--bg);
}
.edit-car-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.edit-car-head h5{margin:0;font-size:14px;font-weight:800}

@media (max-width:640px){
  .drawer-md,.drawer-lg,.drawer-xl{max-width:100%}
}

/* =========== Live indicator (realtime) =========== */
.live-dot{
  display:flex;align-items:center;gap:6px;
  padding:4px 10px;border-radius:999px;
  background:var(--ok-soft);border:1px solid #bbf7d0;
  color:#15803d;font-size:11px;font-weight:800;letter-spacing:.08em;
  margin-bottom:8px;width:fit-content;
  transition:var(--transition);
}
.live-dot.off{background:var(--line-2);border-color:var(--line);color:var(--muted)}
.live-dot.flash{transform:scale(1.04);background:#dcfce7;border-color:#86efac}
.live-pulse{
  width:7px;height:7px;border-radius:50%;background:var(--ok);
  box-shadow:0 0 0 0 rgba(22,163,74,.5);
  animation:livePulse 1.8s ease-out infinite;
}
.live-dot.off .live-pulse{background:var(--muted);animation:none;box-shadow:none}
@keyframes livePulse{
  0%   { box-shadow:0 0 0 0 rgba(22,163,74,.5)  }
  60%  { box-shadow:0 0 0 8px rgba(22,163,74,0) }
  100% { box-shadow:0 0 0 0 rgba(22,163,74,0)   }
}

/* =========== Audit log list =========== */
.audit-list{display:flex;flex-direction:column;gap:10px}
.audit-item{
  display:flex;gap:12px;padding:12px 14px;
  background:var(--line-2);border-radius:10px;
  border-left:3px solid var(--ink-3);
}
.audit-item.audit-ok    {border-left-color:var(--ok)}
.audit-item.audit-info  {border-left-color:#7c3aed}
.audit-item.audit-danger{border-left-color:var(--danger)}
.audit-icon{
  width:28px;height:28px;border-radius:8px;background:#fff;
  display:grid;place-items:center;flex-shrink:0;color:var(--ink-2);
}
.audit-ok    .audit-icon{color:var(--ok)}
.audit-info  .audit-icon{color:#7c3aed}
.audit-danger .audit-icon{color:var(--danger)}
.audit-body{flex:1;min-width:0}
.audit-head{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.audit-action{font-size:13.5px;font-weight:700;color:var(--ink)}
.audit-when{font-size:11.5px;color:var(--muted);font-family:'JetBrains Mono',ui-monospace,monospace}
.audit-actor{font-size:12px;color:var(--ink-3);margin-top:2px}
.audit-diff{margin-top:8px;display:flex;flex-direction:column;gap:4px}
.audit-row{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-size:12px;background:#fff;border-radius:6px;padding:5px 10px;
}
.audit-field{font-weight:700;color:var(--ink-3);min-width:100px}
.audit-from{color:var(--muted);text-decoration:line-through;font-weight:500}
.audit-to{color:var(--ink);font-weight:700}

/* =========== Action Result modal (booking confirm/reschedule/cancel) =========== */
.action-result{
  text-align:center;padding:8px 4px 4px;
}
.action-icon{
  width:72px;height:72px;border-radius:50%;
  display:grid;place-items:center;margin:0 auto 14px;
  position:relative;
  animation:actionPop .5s cubic-bezier(.2,.7,.2,1);
}
.action-icon::before{
  content:"";position:absolute;inset:-8px;border-radius:50%;
  background:currentColor;opacity:.08;
  animation:actionPulse 2s ease-in-out infinite;
}
.action-ok    .action-icon{background:var(--ok-soft);    color:var(--ok)}
.action-info  .action-icon{background:#f3e8ff;          color:#7c3aed}
.action-danger .action-icon{background:var(--danger-soft);color:var(--danger)}
@keyframes actionPop{
  0%  { transform:scale(.4); opacity:0 }
  60% { transform:scale(1.08); opacity:1 }
  100%{ transform:scale(1); opacity:1 }
}
@keyframes actionPulse{
  0%,100%{ transform:scale(1);   opacity:.08 }
  50%    { transform:scale(1.15);opacity:.04 }
}

.action-title{
  margin:6px 0 14px;font-size:22px;font-weight:800;letter-spacing:-.015em;color:var(--ink);
  animation:actionFadeUp .5s .12s both cubic-bezier(.2,.7,.2,1);
}

.action-ref{
  display:inline-flex;flex-direction:column;align-items:center;gap:4px;
  padding:14px 28px;border-radius:14px;
  background:linear-gradient(180deg, var(--brand-soft), #fff);
  border:1px solid var(--brand-line);
  margin:0 auto 16px;
  animation:actionFadeUp .5s .2s both cubic-bezier(.2,.7,.2,1);
}
.action-ref .lbl{font-size:11px;color:var(--ink-3);font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.action-ref .val{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:24px;font-weight:800;color:var(--brand);letter-spacing:.08em;
}

.action-email{
  display:flex;align-items:center;gap:10px;
  padding:11px 16px;border-radius:12px;
  margin:0 auto 18px;max-width:fit-content;
  font-size:13.5px;font-weight:600;
  animation:actionFadeUp .5s .28s both cubic-bezier(.2,.7,.2,1);
}
.action-email.ok    {background:var(--ok-soft);   color:#15803d;border:1px solid #bbf7d0}
.action-email.warn  {background:var(--warn-soft); color:#92400e;border:1px solid #fde2b3}
.action-email.mute  {background:var(--line-2);    color:var(--ink-3);border:1px solid var(--line)}

.action-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  text-align:left;margin:6px 0 4px;
  animation:actionFadeUp .5s .36s both cubic-bezier(.2,.7,.2,1);
}
.action-grid > div{
  background:var(--line-2);border-radius:10px;padding:10px 14px;
  display:flex;flex-direction:column;gap:2px;
}
.action-grid .l{font-size:11px;color:var(--ink-3);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.action-grid .v{font-size:14px;font-weight:700;color:var(--ink)}

.action-hint{
  display:inline-flex;align-items:center;gap:6px;justify-content:center;
  margin:14px 0 0;font-size:12.5px;color:var(--muted);
  animation:actionFadeUp .5s .44s both cubic-bezier(.2,.7,.2,1);
}

@keyframes actionFadeUp{
  from { opacity:0; transform:translateY(8px) }
  to   { opacity:1; transform:translateY(0) }
}

@media (max-width:520px){
  .action-grid{grid-template-columns:1fr}
  .action-title{font-size:18px}
}

/* =========== Toast =========== */
.toast-wrap{position:fixed;top:20px;right:20px;z-index:200;display:flex;flex-direction:column;gap:10px}
.toast{
  background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 16px;
  box-shadow:var(--shadow);min-width:280px;animation:toastIn .25s cubic-bezier(.2,.7,.2,1);
  display:flex;gap:10px;align-items:flex-start;
}
.toast .icon{width:24px;height:24px;border-radius:6px;display:grid;place-items:center;font-weight:800;flex-shrink:0}
.toast.ok .icon{background:var(--ok-soft);color:var(--ok)}
.toast.err .icon{background:var(--danger-soft);color:var(--danger)}
.toast.info .icon{background:var(--info-soft);color:var(--info)}
.toast .msg{font-size:13.5px;line-height:1.45}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}

/* =========== Contact section =========== */
.contact-section{background:linear-gradient(180deg, var(--bg) 0%, #fff 60%);border-top:1px solid var(--line);padding-top:60px;padding-bottom:60px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:32px}
.contact-card{
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;
  transition:var(--transition);
}
.contact-card:hover{border-color:var(--ink-3)}
.contact-card-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:18px}
.contact-card-head h3{margin:0;font-size:16px;font-weight:800;color:var(--ink);letter-spacing:-.005em}
.contact-card-head .icon-tile{width:36px;height:36px;border-radius:10px}

.contact-list{list-style:none;padding:0;margin:0 0 18px;display:flex;flex-direction:column;gap:10px}
.contact-list li{
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:10px 14px;background:var(--line-2);border-radius:10px;
  font-size:13.5px;
}
.contact-l{color:var(--muted);font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.06em}
.contact-v{color:var(--ink);font-weight:700;text-decoration:none;text-align:right;word-break:break-all}
a.contact-v:hover{color:var(--brand)}

.contact-cta{display:flex;gap:10px;flex-wrap:wrap}
.contact-cta .btn{flex:1;min-width:120px}

/* Social grid */
.social-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.social-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;background:var(--line-2);border-radius:10px;
  text-decoration:none;color:var(--ink);transition:var(--transition);
}
.social-item:hover{background:#fff;border:1px solid var(--ink-3);transform:translateY(-1px);padding:9px 11px}
.social-ico{
  width:32px;height:32px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;
}
.social-item div{display:flex;flex-direction:column;min-width:0}
.social-item strong{font-size:12.5px;font-weight:800;color:var(--ink);line-height:1.2}
.social-item span{font-size:11.5px;color:var(--muted);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Branch contacts */
.branch-contacts{margin-top:8px}
.branch-contacts-h{
  font-size:13px;font-weight:700;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;
  margin:0 0 14px;text-align:center;
}
.branch-contact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.branch-contact-card{
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:14px 16px;background:#fff;border:1px solid var(--line);border-radius:12px;
  text-decoration:none;color:var(--ink);transition:var(--transition);
}
.branch-contact-card:hover{border-color:var(--brand);background:var(--brand-soft);transform:translateY(-1px)}
.branch-contact-meta{display:flex;flex-direction:column;gap:2px;min-width:0}
.branch-contact-name{font-size:13.5px;font-weight:800;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.branch-contact-addr{font-size:11.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.branch-contact-phone{
  display:inline-flex;align-items:center;gap:5px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:12.5px;font-weight:700;color:var(--brand);
  flex-shrink:0;
}

@media (max-width:980px){
  .contact-grid{grid-template-columns:1fr}
  .branch-contact-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .social-grid{grid-template-columns:1fr}
  .branch-contact-grid{grid-template-columns:1fr}
}

/* =========== Footer =========== */
.site-footer{
  margin-top:60px;padding:32px 24px;border-top:1px solid var(--line);
  background:#fff;color:var(--muted);font-size:13.5px;text-align:center;
}

/* =========== Admin layout =========== */
.admin-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.admin-side{
  background:#fff;border-right:1px solid var(--line);
  display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;
}
.admin-side .brand{padding:20px 18px;border-bottom:1px solid var(--line)}
.admin-nav{padding:12px;flex:1;display:flex;flex-direction:column;gap:4px}
.admin-nav a{
  display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;
  color:var(--ink-3);font-weight:600;font-size:14px;cursor:pointer;
  transition:var(--transition);position:relative;
}
.admin-nav a:hover{background:var(--line-2);color:var(--ink)}
.admin-nav a.active{background:var(--ink);color:#fff}
.admin-nav a.active::after{
  content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);
  width:3px;height:18px;background:var(--brand);border-radius:0 3px 3px 0;
}
.admin-nav .nav-ico{color:currentColor}

/* Per-branch sub-nav under "ปฏิทินงาน" */
.admin-nav-sub{
  display:flex;flex-direction:column;gap:2px;
  margin:2px 0 6px 6px;
  padding-left:14px;
  border-left:1.5px dashed var(--line);
}
.admin-nav-sub a.sub{
  display:flex;align-items:center;gap:9px;
  padding:6px 10px;border-radius:8px;
  color:var(--ink-3);font-weight:600;font-size:12.5px;
  cursor:pointer;transition:var(--transition);
  position:relative;
}
.admin-nav-sub a.sub:hover{background:var(--line-2);color:var(--ink)}
.admin-nav-sub a.sub.active{background:var(--ink);color:#fff}
.admin-nav-sub a.sub.active::after{
  content:""; position:absolute; left:-15px; top:50%; transform:translateY(-50%);
  width:3px; height:14px; background:var(--brand); border-radius:0 3px 3px 0;
}
.sub-dot{
  width:9px;height:9px;border-radius:50%;flex-shrink:0;
  box-shadow:0 0 0 2px rgba(255,255,255,.4);
}
.dot-thaphra { background:#ff5b1f }
.dot-ramintra{ background:#2563eb }
.dot-kanchana{ background:#7c3aed }
.dot-chonburi{ background:#10b981 }
.admin-side .foot{padding:16px;border-top:1px solid var(--line)}
.admin-main{padding:24px 28px;background:var(--bg);min-width:0}
.admin-topbar{
  display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;
  flex-wrap:wrap;gap:12px;
}
.admin-topbar h2{margin:0;font-size:22px;font-weight:800}

.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:14px}
.kpi{
  background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px 18px 16px;
  position:relative;overflow:hidden;
  transition:var(--transition);
}
.kpi:hover{border-color:var(--ink);transform:translateY(-1px)}
.kpi::after{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--brand);
  opacity:0;transition:var(--transition);
}
.kpi:hover::after{opacity:1}
.kpi .l{color:var(--muted);font-size:12.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.kpi .v{font-size:32px;font-weight:800;margin-top:6px;color:var(--ink);letter-spacing:-.02em;line-height:1.1}
.kpi .d{font-size:12.5px;font-weight:700;margin-top:6px;display:flex;align-items:center;gap:4px;color:var(--muted)}
.kpi .d.up{color:var(--ok)}
.kpi .d.down{color:var(--danger)}
.kpi .d.flat{color:var(--muted)}

/* Mini stat row */
.mini-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:6px;
}
.mini{
  background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;
  display:flex;flex-direction:column;gap:2px;
}
.mini-l{color:var(--muted);font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.mini-v{font-size:18px;font-weight:800;color:var(--ink);letter-spacing:-.01em}

/* topbar subtitle */
.admin-topbar h2{margin:0;font-size:24px;font-weight:800;letter-spacing:-.01em;color:var(--ink)}
.topbar-sub{font-size:13px;color:var(--muted);margin-top:2px;font-weight:500}

/* Card heading with right-side legend */
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px;flex-wrap:wrap}
.card-head h3{margin:0;font-size:16px}
.card-legend{display:flex;gap:14px;font-size:12px;color:var(--muted);font-weight:600}
.card-legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px;vertical-align:middle}

/* === Smooth line chart (Daily bookings) === */
.chart-host{display:block;width:100%}
.chart-wrap{position:relative;width:100%;height:240px}
.chart-line{width:100%;height:100%;display:block;overflow:visible}
.chart-line .grid line{stroke:var(--line-2);stroke-width:1}
.chart-line .axis-y text{font-size:11px;fill:var(--muted);font-family:'JetBrains Mono',ui-monospace,monospace;font-weight:600}
.chart-line .axis-x text{font-size:11px;fill:var(--muted);font-weight:600}
.chart-line .area{stroke:none;transition:opacity .2s}
.chart-line .line{
  fill:none;stroke:var(--brand);stroke-width:2.4;
  stroke-linecap:round;stroke-linejoin:round;
}
.chart-line .avg-line{stroke:var(--ink-3);stroke-width:1;stroke-dasharray:4,4;opacity:.55}
.chart-line .avg-label{font-size:10px;fill:var(--ink-3);font-weight:700}
.chart-line .dot{fill:#fff;stroke:var(--brand);stroke-width:2;cursor:pointer;transition:all .15s}
.chart-line .dot.peak{fill:var(--brand);stroke:#fff;stroke-width:2.5;filter:drop-shadow(0 2px 4px rgba(255,91,31,.4))}
.chart-line .dot.zero{stroke:var(--line);stroke-width:1.5}
.chart-line .dot.hover{r:5.5;stroke-width:3}
.chart-line .cursor-line{stroke:var(--ink-3);stroke-width:1;stroke-dasharray:3,3;opacity:.4;pointer-events:none}
.chart-line .hover-zone:hover{fill:rgba(255,91,31,.04)}

.chart-tooltip{
  position:absolute;background:var(--ink);color:#fff;
  padding:10px 14px;border-radius:10px;font-size:12.5px;
  pointer-events:none;opacity:0;transform:translateY(4px);
  transition:opacity .15s, transform .15s;
  box-shadow:0 8px 22px rgba(0,0,0,.18);
  min-width:140px;z-index:5;
}
.chart-tooltip.show{opacity:1;transform:translateY(0)}
.chart-tooltip::after{
  content:"";position:absolute;left:50%;bottom:-6px;transform:translateX(-50%);
  width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;
  border-top:6px solid var(--ink);
}
.chart-tooltip .tip-date{font-size:11px;color:rgba(255,255,255,.55);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}
.chart-tooltip .tip-row{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;line-height:1.6}
.chart-tooltip .tip-row b{margin-left:auto;font-size:14px;font-weight:800}
.chart-tooltip .tip-row .dot{width:8px;height:8px;border-radius:50%;background:var(--brand);flex-shrink:0}
.chart-tooltip .tip-bad .dot{background:#cccccc}
.chart-tooltip .tip-bad b{color:#bbb}

.chart-meta{
  display:flex;gap:18px;margin-top:14px;flex-wrap:wrap;
  padding-top:12px;border-top:1px solid var(--line-2);
}
.chart-meta .meta-item{
  display:flex;align-items:center;gap:7px;
  font-size:12.5px;color:var(--ink-3);font-weight:600;
}
.chart-meta .meta-item b{color:var(--ink);font-weight:800;font-size:14px;font-variant-numeric:tabular-nums}
.chart-meta .ind{width:10px;height:10px;border-radius:3px}
.chart-meta .ind-brand{background:var(--brand)}
.chart-meta .ind-peak{background:var(--brand);box-shadow:0 0 0 2px var(--brand-soft)}
.chart-meta .ind-avg{background:transparent;border:1.5px dashed var(--ink-3)}
.chart-meta .ind-bad{background:#cccccc}

/* Donut chart wrapper */
.donut-wrap{display:flex;align-items:center;gap:24px;padding:12px 4px}
.donut{
  width:140px;height:140px;border-radius:50%;flex-shrink:0;
  background:conic-gradient(var(--brand) 0% 60%, #e5e5e5 60% 100%);
  display:grid;place-items:center;position:relative;
}
.donut::after{
  content:"";position:absolute;inset:18px;background:#fff;border-radius:50%;
}
.donut-center{position:relative;z-index:1;text-align:center}
.donut-center .v{font-size:22px;font-weight:800;color:var(--ink);line-height:1}
.donut-center .l{font-size:10.5px;color:var(--muted);font-weight:600;text-transform:uppercase}
.donut-legend{flex:1;display:flex;flex-direction:column;gap:8px}
.donut-leg{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600}
.donut-leg .swatch{width:14px;height:14px;border-radius:4px;flex-shrink:0}
.donut-leg .pct{margin-left:auto;color:var(--muted);font-weight:700}

/* Ranked list (branches / cameras / hours) */
.rank-list{display:flex;flex-direction:column;gap:10px}
.rank-item{display:flex;align-items:center;gap:10px;font-size:13px}
.rank-item .label{font-weight:600;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rank-item .bar{flex:1.6;height:8px;background:var(--line-2);border-radius:999px;overflow:hidden;min-width:0}
.rank-item .bar > span{display:block;height:100%;background:linear-gradient(90deg,var(--brand),var(--brand-2));border-radius:999px}
.rank-item .val{width:36px;text-align:right;font-weight:800;color:var(--ink)}
.rank-item .num{width:22px;height:22px;background:var(--line-2);border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:11px;color:var(--ink-3);flex-shrink:0}
.rank-item.top .num{background:var(--brand);color:#fff}

/* Day-of-week heatmap */
.dow-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-top:6px}
.dow-cell{
  aspect-ratio:1;border-radius:8px;display:grid;place-items:center;
  font-size:11px;font-weight:700;color:var(--ink);position:relative;
  background:var(--line-2);
}
.dow-cell .lab{font-size:10px;font-weight:700;color:var(--muted);position:absolute;top:4px;left:6px}
.dow-cell .num{font-size:18px;font-weight:800}

/* Activity list (recent / upcoming) */
.activity-list{display:flex;flex-direction:column;divide-y:1px}
.activity-item{
  display:flex;align-items:center;gap:12px;padding:10px 0;
  border-bottom:1px solid var(--line-2);cursor:pointer;
  transition:var(--transition);
}
.activity-item:last-child{border-bottom:none}
.activity-item:hover{background:var(--line-2);margin:0 -12px;padding:10px 12px;border-radius:8px;border-bottom-color:transparent}
.activity-when{
  text-align:center;flex-shrink:0;width:48px;
}
.activity-when .day{font-size:18px;font-weight:800;color:var(--ink);line-height:1}
.activity-when .mon{font-size:10.5px;color:var(--muted);font-weight:700;text-transform:uppercase;margin-top:2px}
.activity-body{flex:1;min-width:0}
.activity-title{font-weight:700;font-size:13.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.activity-sub{font-size:12px;color:var(--muted);margin-top:2px;display:flex;gap:8px;flex-wrap:wrap}
.activity-ref{font-family:'JetBrains Mono',ui-monospace,monospace;color:var(--brand);font-weight:700}
.activity-time{font-weight:700;font-size:12.5px;color:var(--ink-3);flex-shrink:0}

@media (max-width:980px){
  .mini-grid{grid-template-columns:repeat(2,1fr)}
  .donut-wrap{flex-direction:column}
}

/* table */
.tbl{
  width:100%;border-collapse:separate;border-spacing:0;
  background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;
}
.tbl th,.tbl td{padding:12px 14px;text-align:left;font-size:13.5px;border-bottom:1px solid var(--line-2)}
.tbl thead th{background:var(--line-2);font-weight:700;color:var(--ink-2);font-size:12.5px;text-transform:uppercase;letter-spacing:.04em}
.tbl tbody tr:hover{background:#fafbfd}
.tbl tbody tr:last-child td{border-bottom:none}

/* status pills */
.st{padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700;display:inline-block}
.st-confirmed{background:var(--ok-soft);color:var(--ok)}
.st-pending  {background:var(--warn-soft);color:var(--warn)}
.st-completed{background:var(--info-soft);color:var(--info)}
.st-cancelled{background:var(--danger-soft);color:var(--danger)}
.st-rescheduled{background:#f3e8ff;color:#7c3aed}

/* toggle switch */
.switch{position:relative;display:inline-block;width:46px;height:26px}
.switch input{opacity:0;width:0;height:0}
.switch .sl{
  position:absolute;cursor:pointer;inset:0;background:var(--line);border-radius:999px;
  transition:var(--transition);
}
.switch .sl::before{
  content:"";position:absolute;height:20px;width:20px;left:3px;top:3px;background:#fff;
  border-radius:50%;transition:var(--transition);box-shadow:var(--shadow-sm);
}
.switch input:checked + .sl{background:linear-gradient(135deg,var(--brand),var(--brand-2))}
.switch input:checked + .sl::before{transform:translateX(20px)}

/* tabs */
.tabs{display:flex;gap:6px;border-bottom:1px solid var(--line);margin-bottom:18px;overflow-x:auto}
.tabs button{
  background:transparent;border:none;padding:12px 16px;font-weight:700;color:var(--muted);
  cursor:pointer;font-size:14px;border-bottom:2px solid transparent;white-space:nowrap;
}
.tabs button.active{color:var(--brand);border-bottom-color:var(--brand)}

/* search bar */
.search-bar{
  display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:14px;
}
.search-bar .input,.search-bar .select{height:40px}

/* calendar */
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cal-head h3{margin:0;font-size:18px}
.cal-grid{
  display:grid;grid-template-columns:repeat(7,1fr);
  background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden;
  gap:1px;
}
.cal-dow{background:var(--line-2);padding:8px;text-align:center;font-weight:700;font-size:12px;color:var(--muted)}
.cal-cell{
  background:#fff;min-height:96px;padding:8px;display:flex;flex-direction:column;gap:4px;
  cursor:pointer;transition:var(--transition);
}
.cal-cell:hover{background:#fafbfd}
.cal-cell.muted{background:var(--line-2);color:var(--muted)}
.cal-cell.today .cal-day{color:var(--brand);font-weight:800}
.cal-day{font-weight:700;font-size:13px}
.cal-pill{
  background:var(--brand-soft);color:var(--brand);font-size:11px;padding:2px 6px;border-radius:6px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:700;
  border-left:3px solid var(--brand);
  display:flex;align-items:center;gap:5px;
}
/* tiny circle/square dot before time — distinguishes Onsite vs In-Store */
.cal-pill::before{
  content:"";
  width:6px;height:6px;
  border-radius:50%;
  background:currentColor;
  flex-shrink:0;
  opacity:.85;
}
.cal-pill.onsite::before{
  /* Onsite → square (different shape = easy visual scan) */
  border-radius:1px;
}
.cal-pill.onsite{
  /* Onsite stronger: dashed left bar + italic */
  border-left-style:dashed;
  border-left-width:4px;
  font-style:italic;
}

/* Per-branch color coding — overrides default brand color, applies to bg + border + text */
.cal-pill.branch-thaphra { background:#fff4ed; color:#c4421a; border-left-color:#ff5b1f; }
.cal-pill.branch-ramintra{ background:#eef4ff; color:#1e40af; border-left-color:#2563eb; }
.cal-pill.branch-kanchana{ background:#f3edff; color:#6d28d9; border-left-color:#7c3aed; }
.cal-pill.branch-chonburi{ background:#ecfdf5; color:#047857; border-left-color:#10b981; }

/* Legend chips below the calendar */
.cal-legend{
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;
  margin-top:14px;padding:12px 14px;
  background:var(--line-2);border-radius:10px;
  font-size:12px;
}
.cal-legend-group{display:flex;flex-wrap:wrap;align-items:center;gap:12px}
.cal-legend-title{
  font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);margin-right:2px;
}
.cal-legend-item{
  display:inline-flex;align-items:center;gap:6px;
  font-weight:600;color:var(--ink-3);
}
.cal-legend-swatch{
  width:14px;height:14px;border-radius:4px;
  border-left:3px solid;flex-shrink:0;
}
.cal-legend-divider{
  width:1px;height:18px;background:var(--line);
}
.cal-legend-shape{
  width:8px;height:8px;background:var(--ink-3);flex-shrink:0;
}
.cal-legend-shape.cls-instore{ border-radius:50% }
.cal-legend-shape.cls-onsite { border-radius:1px }
.cal-legend-item i{font-style:italic}

/* Login */
.login-shell{
  min-height:100vh;display:grid;place-items:center;padding:20px;
  background:linear-gradient(135deg,#fff8f3 0%,var(--bg) 60%);
}
.login-card{
  background:#fff;border-radius:20px;border:1px solid var(--line);
  width:100%;max-width:420px;padding:32px;box-shadow:var(--shadow-lg);
}
.login-card h1{font-size:22px;margin:0 0 6px}
.login-card p{color:var(--muted);margin:0 0 22px;font-size:14px}

/* spinner */
.spin{
  width:18px;height:18px;border-radius:50%;
  border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;
  animation:spin 0.7s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.btn .spin{display:none}
.btn.loading .spin{display:inline-block}
.btn.loading .label{opacity:.7}

/* alert */
.alert{
  padding:14px 16px;border-radius:12px;display:flex;gap:12px;align-items:flex-start;
  font-size:14px;line-height:1.5;
}
.alert .ico{flex-shrink:0;font-size:18px;line-height:1}
.alert-warn  {background:var(--warn-soft);color:#92400e;border:1px solid #fde2b3}
.alert-danger{background:var(--danger-soft);color:#991b1b;border:1px solid #f8c5c2}
.alert-ok    {background:var(--ok-soft);color:#0f6e3a;border:1px solid #b8e8c9}
.alert-info  {background:var(--info-soft);color:#0a4cb1;border:1px solid #c4dafc}

/* =========== Service cards in hero =========== */
.service-card{
  position:relative;padding:18px;border-radius:16px;
  background:#fff;border:1px solid var(--line);
  display:flex;flex-direction:column;gap:6px;
}
.service-icon{
  width:44px;height:44px;border-radius:12px;
  display:grid;place-items:center;margin-bottom:4px;
}
.service-card h4{margin:6px 0 4px;font-size:15.5px;font-weight:800;color:var(--ink)}

/* H3 inline icon */
h3.with-icon, h4.with-icon{display:flex;align-items:center;gap:10px;color:var(--ink)}
h3.with-icon svg, h4.with-icon svg{color:var(--brand)}

/* Alert layout — icon left */
.alert{align-items:center}
.alert svg{flex-shrink:0;color:currentColor}
.alert .ico{color:currentColor;font-size:18px;line-height:1}

/* drawer-section h4 svg */
.drawer-section h4 svg{color:var(--brand)}

/* card-h icon-tile inside card-head — keep tighter */
.card-head .card-h{margin-bottom:0}

/* Service switch icon-aware */
.service-switch button{display:flex;align-items:center;justify-content:center;gap:8px}
.service-switch button svg{width:16px;height:16px;opacity:.7}
.service-switch button.active svg{opacity:1;color:var(--brand)}

/* hero CTA arrow icon nudge */
.hero-cta .btn svg{transition:transform .2s}
.hero-cta .btn:hover svg{transform:translateX(2px)}

/* =========== Icons (Lucide-style SVG) =========== */
svg{display:inline-block;vertical-align:middle;flex-shrink:0}
.icon-btn-square{
  width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:#fff;
  display:inline-grid;place-items:center;cursor:pointer;color:var(--ink-3);
  transition:var(--transition);
}
.icon-btn-square:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.with-icon{display:inline-flex;align-items:center;gap:8px}
.with-icon-lg{display:inline-flex;align-items:center;gap:10px}

/* nav icon wrapper */
.nav-ico{
  width:18px;height:18px;display:inline-grid;place-items:center;color:currentColor;
}

/* circular icon badge (e.g. inside cards) */
.icon-tile{
  width:36px;height:36px;border-radius:10px;background:var(--brand-soft);color:var(--brand);
  display:inline-grid;place-items:center;flex-shrink:0;
}
.icon-tile-ink{background:var(--ink);color:#fff}
.icon-tile-line{background:#fff;border:1px solid var(--line);color:var(--ink-2)}
.icon-tile-sm{width:28px;height:28px;border-radius:8px}

/* utility */
.hide{display:none !important}
.muted{color:var(--muted)}
.right{text-align:right}
.center{text-align:center}
.mt-0{margin-top:0}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}
.flex{display:flex}.flex-col{flex-direction:column}.gap-1{gap:8px}.gap-2{gap:16px}.gap-3{gap:24px}
.items-center{align-items:center}.justify-between{justify-content:space-between}
.flex-wrap{flex-wrap:wrap}
.full{width:100%}

/* =========== Responsive =========== */
@media (max-width: 980px){
  .hero{padding:64px 18px 48px}
  .hero-title{font-size:44px;line-height:1.2}
  .grid-3,.grid-4{grid-template-columns:1fr 1fr}
  .row-3,.row-4{grid-template-columns:1fr 1fr}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .admin-shell{grid-template-columns:1fr}
  .admin-side{position:static;height:auto;flex-direction:row;flex-wrap:wrap}
  .admin-side .brand{border-bottom:none;border-right:1px solid var(--line);padding:14px}
  .admin-nav{flex-direction:row;flex-wrap:wrap;padding:8px;gap:6px}
  .admin-nav a{padding:8px 12px;font-size:13px}
  .admin-nav a.active::after{display:none}
  .admin-side .foot{display:none}
  .result-info{grid-template-columns:1fr}
}
@media (max-width: 760px){
  /* Mobile drop-down nav */
  .nav-toggle{display:inline-flex}
  .nav{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;
    background:#fff;border-bottom:1px solid var(--line);
    padding:14px 18px;gap:4px;
    transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:transform .22s cubic-bezier(.2,.7,.2,1), opacity .18s;
    box-shadow:0 12px 28px rgba(0,0,0,.08);
  }
  .nav.open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav a{padding:12px 14px;font-size:15px;border-radius:10px}
  .nav .nav-external{justify-content:space-between}
  .site-header .inner{position:relative}
}
@media (max-width: 640px){
  .section{padding:32px 16px}
  .hero{padding:48px 16px 36px}
  .hero-title{font-size:32px;line-height:1.2;letter-spacing:-.02em}
  .hero p{font-size:15px}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .row-2,.row-3,.row-4{grid-template-columns:1fr}
  .seg-2,.seg-4{grid-template-columns:1fr 1fr}
  .slots{grid-template-columns:repeat(3,1fr)}
  .steps{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .map-container{height:300px}
  .modal{max-height:96vh}
  .cal-cell{min-height:64px;padding:4px;font-size:11px}
  .cal-pill{display:none}
  .cal-cell.has-bookings::after{content:"●";color:var(--brand);font-size:14px}
}
