/* ============================================================
   Nuad Now — Design System
   Warm spa / cute cartoon. Cream + chocolate + plum + gold.
   ============================================================ */

:root{
  /* surfaces */
  --cream-50:#FCF8F1;
  --cream-100:#F8F0E3;
  --cream-200:#F1E6D4;
  --cream-300:#E8D9C2;
  --paper:#FFFFFF;

  /* ink / browns (logo outline family) */
  --ink:#4A2B22;
  --ink-900:#36190F;
  --ink-700:#6A4435;
  --ink-500:#90705F;
  --ink-300:#B9A493;

  /* plum (sash / pants) — primary accent, tweakable via --accent */
  --accent:#864A5E;
  --accent-600:color-mix(in oklab, var(--accent), #000 14%);
  --accent-700:color-mix(in oklab, var(--accent), #000 30%);
  --accent-100:color-mix(in oklab, var(--accent), #fff 80%);
  --accent-50:color-mix(in oklab, var(--accent), #fff 90%);

  /* gold (trim) */
  --gold:#C99A5B;
  --gold-600:#B07F3E;
  --gold-100:#F4E7CF;

  /* sage (available / success) */
  --sage:#7E9A6E;
  --sage-600:#637D54;
  --sage-100:#E5EDDC;

  --blush:#F2C6BC;

  /* status */
  --ok:var(--sage);
  --warn:#D99A4E;
  --bad:#C56A5C;

  /* shape */
  --bw:2.5px;
  --r-sm:12px;
  --r-md:18px;
  --r-lg:26px;
  --r-xl:34px;
  --r-pill:999px;
  --drop:rgba(54,25,15,.10);

  --shadow-card:0 6px 0 rgba(74,43,34,.07), 0 14px 30px -14px rgba(74,43,34,.35);
  --shadow-pop:0 10px 0 rgba(74,43,34,.10), 0 26px 50px -18px rgba(74,43,34,.5);

  --font-display:'Baloo Thai 2', system-ui, sans-serif;
  --font-body:'Mali', system-ui, sans-serif;

  --maxw:1180px;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;overflow-x:hidden;}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream-50);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
button{font-family:inherit;cursor:pointer;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;margin:0;color:var(--ink);line-height:1.15;}
.t-display{font-family:var(--font-display);}
.muted{color:var(--ink-500);}
.center{text-align:center;}

/* ---- decorative page backdrop ---- */
.app-bg{
  position:fixed; inset:0; z-index:0; overflow:hidden;
  background:
    radial-gradient(1200px 700px at 80% -10%, var(--accent-50), transparent 60%),
    radial-gradient(900px 600px at -5% 100%, var(--sage-100), transparent 55%),
    var(--cream-50);
}
.app-bg .blob{position:absolute;opacity:.5;}

/* floating flower decor */
.flower-decor{position:absolute;opacity:.10;animation:floaty 9s ease-in-out infinite;}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-14px) rotate(8deg)}}

/* ============================================================
   BUTTONS — chunky candy / game style
   ============================================================ */
.btn{
  --b:var(--accent); --bs:var(--accent-700); --fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--font-display);font-weight:700;font-size:1.05rem;
  color:var(--fg);background:var(--b);
  border:var(--bw) solid var(--ink);
  border-radius:var(--r-pill);
  padding:.62em 1.3em; line-height:1;
  box-shadow:0 5px 0 var(--bs);
  transition:transform .08s ease, box-shadow .08s ease, filter .15s;
  user-select:none; white-space:nowrap;
}
.btn:hover{filter:brightness(1.04);}
.btn:active{transform:translateY(4px);box-shadow:0 1px 0 var(--bs);}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:0 5px 0 var(--bs);}
.btn.lg{font-size:1.25rem;padding:.7em 1.6em;}
.btn.sm{font-size:.92rem;padding:.5em 1em;box-shadow:0 4px 0 var(--bs);}
.btn.block{display:flex;width:100%;}

.btn.secondary{--b:var(--paper);--bs:var(--cream-300);--fg:var(--ink);}
.btn.gold{--b:var(--gold);--bs:var(--gold-600);--fg:#fff;}
.btn.sage{--b:var(--sage);--bs:var(--sage-600);--fg:#fff;}
.btn.ghost{--b:transparent;--bs:transparent;border-color:transparent;box-shadow:none;color:var(--ink);}
.btn.ghost:hover{background:rgba(74,43,34,.06);}
.btn.danger{--b:#fff;--bs:var(--cream-300);--fg:var(--bad);border-color:var(--bad);}

/* icon button */
.iconbtn{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:var(--r-pill);
  border:var(--bw) solid var(--ink);background:var(--paper);color:var(--ink);
  box-shadow:0 4px 0 var(--cream-300);transition:transform .08s,box-shadow .08s;
}
.iconbtn:hover{filter:brightness(.99);}
.iconbtn:active{transform:translateY(3px);box-shadow:0 1px 0 var(--cream-300);}

/* ============================================================
   CARDS / SURFACES
   ============================================================ */
.card{
  background:var(--paper);
  border:var(--bw) solid var(--ink);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-card);
}
.card.flat{box-shadow:0 4px 0 rgba(74,43,34,.06);}
.card.soft{border-color:var(--cream-300);}
.pad{padding:24px;}
.pad-lg{padding:32px;}

.chip{
  display:inline-flex;align-items:center;gap:.4em;
  font-family:var(--font-display);font-weight:600;font-size:.85rem;
  padding:.32em .8em;border-radius:var(--r-pill);
  border:2px solid var(--ink);background:var(--cream-100);color:var(--ink);
}
.chip.sage{background:var(--sage-100);border-color:var(--sage-600);color:var(--sage-600);}
.chip.plum{background:var(--accent-100);border-color:var(--accent-600);color:var(--accent-600);}
.chip.gold{background:var(--gold-100);border-color:var(--gold-600);color:var(--gold-600);}
.chip.ghost{background:transparent;border-color:var(--cream-300);color:var(--ink-500);}

.dot{width:9px;height:9px;border-radius:50%;display:inline-block;}

/* ============================================================
   INPUTS
   ============================================================ */
.field{display:flex;flex-direction:column;gap:6px;}
.field label{font-family:var(--font-display);font-weight:600;font-size:.95rem;color:var(--ink-700);}
.input{
  font-family:var(--font-body);font-size:1rem;color:var(--ink);
  background:var(--cream-50);
  border:var(--bw) solid var(--cream-300);
  border-radius:var(--r-md);
  padding:.78em 1em;width:100%;transition:border-color .15s, box-shadow .15s, background .15s;
}
.input::placeholder{color:var(--ink-300);}
.input:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 4px var(--accent-50);}
.input-wrap{position:relative;}
.input-wrap .ic{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--ink-300);}
.input-wrap .input{padding-left:44px;}

/* ============================================================
   MASCOT + SPEECH BUBBLE
   ============================================================ */
.mascot{display:block;filter:drop-shadow(0 12px 16px rgba(74,43,34,.18));}
.mascot.bob{animation:bob 4s ease-in-out infinite;}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

.bubble{
  position:relative;background:var(--paper);
  border:var(--bw) solid var(--ink);border-radius:var(--r-lg);
  padding:14px 18px;font-family:var(--font-body);color:var(--ink);
  box-shadow:0 5px 0 rgba(74,43,34,.07);max-width:300px;
}
.bubble.lead{font-family:var(--font-display);font-weight:600;}
.bubble::after,.bubble::before{content:"";position:absolute;}
/* tail pointing down-left */
.bubble.tail-bl::before{left:34px;bottom:-16px;border:8px solid transparent;border-top-color:var(--ink);border-right-color:var(--ink);}
.bubble.tail-bl::after{left:37px;bottom:-10px;border:6px solid transparent;border-top-color:var(--paper);border-right-color:var(--paper);}
/* tail pointing left */
.bubble.tail-l::before{left:-16px;top:50%;transform:translateY(-50%);border:9px solid transparent;border-right-color:var(--ink);}
.bubble.tail-l::after{left:-11px;top:50%;transform:translateY(-50%);border:7px solid transparent;border-right-color:var(--paper);}

/* ============================================================
   APP SHELL
   ============================================================ */
.shell{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column;}
.topbar{
  position:sticky;top:0;z-index:30;
  display:flex;align-items:center;gap:18px;
  padding:14px 26px;
  background:rgba(252,248,241,.85);backdrop-filter:blur(10px);
  border-bottom:2.5px solid var(--cream-300);
}
.topbar .brand{display:flex;align-items:center;gap:12px;}
.topbar .brand img{height:42px;display:block;}
.nav{display:flex;gap:6px;margin-left:14px;}
.nav .navlink{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-weight:600;font-size:1rem;
  color:var(--ink-500);background:transparent;border:none;
  padding:.5em 1em;border-radius:var(--r-pill);transition:all .15s;
}
.nav .navlink:hover{color:var(--ink);background:rgba(74,43,34,.06);}
.nav .navlink.active{color:var(--accent);background:var(--accent-100);}
.topbar .spacer{flex:1;}
.avatar{
  width:46px;height:46px;border-radius:50%;border:var(--bw) solid var(--ink);
  background:var(--gold-100);display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:700;color:var(--gold-600);overflow:hidden;
}
.content{flex:1;width:100%;max-width:var(--maxw);margin:0 auto;padding:34px 26px 80px;position:relative;z-index:2;}

.section-title{display:flex;align-items:center;gap:10px;margin-bottom:18px;}
.section-title h2{font-size:1.6rem;}

/* grids */
.grid{display:grid;gap:18px;}
.cols-2{grid-template-columns:repeat(2,1fr);}
.cols-3{grid-template-columns:repeat(3,1fr);}
.cols-4{grid-template-columns:repeat(4,1fr);}

/* ============================================================
   SERVICE CARD
   ============================================================ */
.svc{
  position:relative;text-align:left;background:var(--paper);
  border:var(--bw) solid var(--ink);border-radius:var(--r-lg);
  padding:22px;cursor:pointer;transition:transform .12s, box-shadow .12s;
  box-shadow:var(--shadow-card);
}
.svc:hover{transform:translateY(-4px);}
.svc.sel{box-shadow:0 0 0 4px var(--accent-100), var(--shadow-card);border-color:var(--accent);}
.svc .tok{
  width:64px;height:64px;border-radius:20px;border:var(--bw) solid var(--ink);
  display:flex;align-items:center;justify-content:center;margin-bottom:14px;
}
.svc h3{font-size:1.25rem;}
.svc .meta{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;}
.svc .pick{position:absolute;top:16px;right:16px;width:30px;height:30px;border-radius:50%;
  border:var(--bw) solid var(--cream-300);background:#fff;display:flex;align-items:center;justify-content:center;color:transparent;transition:.15s;}
.svc.sel .pick{background:var(--accent);border-color:var(--ink);color:#fff;}

/* ============================================================
   STEPPER
   ============================================================ */
.stepper{display:flex;align-items:center;gap:0;margin:6px 0 28px;justify-content:center;flex-wrap:wrap;}
.step{display:flex;align-items:center;gap:10px;}
.step .num{
  width:38px;height:38px;border-radius:50%;border:var(--bw) solid var(--ink);
  display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;
  background:#fff;color:var(--ink-300);transition:.2s;
}
.step .lbl{font-family:var(--font-display);font-weight:600;color:var(--ink-300);font-size:.98rem;}
.step.active .num{background:var(--accent);color:#fff;}
.step.active .lbl{color:var(--accent);}
.step.done .num{background:var(--sage);color:#fff;}
.step.done .lbl{color:var(--ink);}
.step .bar{width:46px;height:3px;border-radius:2px;background:var(--cream-300);margin:0 6px;}
.step.done .bar{background:var(--sage);}

/* ============================================================
   DATE PICKER (week strip)
   ============================================================ */
.dates{display:flex;gap:10px;overflow-x:auto;padding:4px 2px 12px;}
.datecard{
  flex:0 0 auto;width:84px;text-align:center;background:var(--paper);
  border:var(--bw) solid var(--cream-300);border-radius:var(--r-md);
  padding:12px 6px;cursor:pointer;transition:.12s;
}
.datecard:hover{border-color:var(--ink-300);}
.datecard .dow{font-family:var(--font-display);font-weight:600;font-size:.82rem;color:var(--ink-500);}
.datecard .dnum{font-family:var(--font-display);font-weight:700;font-size:1.6rem;line-height:1;margin:4px 0;}
.datecard .mon{font-size:.74rem;color:var(--ink-500);}
.datecard.sel{background:var(--accent);border-color:var(--ink);}
.datecard.sel .dow,.datecard.sel .dnum,.datecard.sel .mon{color:#fff;}
.datecard.today{border-color:var(--gold);}
.datecard.dim{opacity:.4;cursor:not-allowed;}

/* ============================================================
   TIME SLOTS
   ============================================================ */
.slot{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:12px 8px;border:var(--bw) solid var(--cream-300);border-radius:var(--r-md);
  background:var(--paper);cursor:pointer;transition:.12s;font-family:var(--font-display);
}
.slot .tm{font-weight:700;font-size:1.15rem;color:var(--ink);}
.slot .st{font-size:.72rem;color:var(--sage-600);font-weight:600;}
.slot:hover{border-color:var(--ink-300);transform:translateY(-2px);}
.slot.sel{background:var(--accent);border-color:var(--ink);}
.slot.sel .tm,.slot.sel .st{color:#fff;}
.slot.full{opacity:.45;cursor:not-allowed;background:var(--cream-100);}
.slot.full .st{color:var(--bad);}
.slot.full:hover{transform:none;}

/* therapist row */
.thera{
  display:flex;align-items:center;gap:14px;padding:14px;
  border:var(--bw) solid var(--cream-300);border-radius:var(--r-md);background:var(--paper);
  cursor:pointer;transition:.12s;
}
.thera:hover{border-color:var(--ink-300);}
.thera.sel{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-100);}
.thera .pic{width:54px;height:54px;border-radius:50%;border:var(--bw) solid var(--ink);overflow:hidden;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:1.3rem;}
.stars{color:var(--gold);letter-spacing:1px;font-size:.9rem;}

/* booking list item */
.bk{display:flex;align-items:center;gap:18px;padding:18px;}
.bk .when{
  flex:0 0 auto;text-align:center;width:78px;
  border-right:2px dashed var(--cream-300);padding-right:14px;
}
.bk .when .d{font-family:var(--font-display);font-weight:700;font-size:1.8rem;line-height:1;color:var(--accent);}
.bk .when .m{font-size:.8rem;color:var(--ink-500);}

/* ============================================================
   MODAL / TOAST
   ============================================================ */
.overlay{position:fixed;inset:0;z-index:60;background:rgba(54,25,15,.45);backdrop-filter:blur(3px);
  display:flex;align-items:center;justify-content:center;padding:24px;animation:fade .2s ease;}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{background:var(--paper);border:var(--bw) solid var(--ink);border-radius:var(--r-xl);
  box-shadow:var(--shadow-pop);max-width:460px;width:100%;padding:34px;text-align:center;animation:pop .28s cubic-bezier(.2,1.3,.5,1);}
@keyframes pop{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}

.toast-wrap{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:80;display:flex;flex-direction:column;gap:8px;}
.toast{display:flex;align-items:center;gap:10px;background:var(--ink);color:#fff;font-family:var(--font-display);font-weight:600;
  padding:.7em 1.2em;border-radius:var(--r-pill);box-shadow:var(--shadow-pop);animation:drop .3s cubic-bezier(.2,1.3,.5,1);}
@keyframes drop{from{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* confetti bits */
.confetti{position:fixed;inset:0;pointer-events:none;z-index:70;overflow:hidden;}
.confetti i{position:absolute;top:-10px;width:10px;height:14px;border-radius:2px;animation:fall linear forwards;}
@keyframes fall{to{transform:translateY(108vh) rotate(680deg);opacity:.9}}

/* misc */
.hr{height:2px;background:var(--cream-200);border:none;border-radius:2px;margin:18px 0;}
.kv{display:flex;justify-content:space-between;align-items:center;padding:9px 0;}
.kv .k{color:var(--ink-500);font-family:var(--font-body);}
.kv .v{font-family:var(--font-display);font-weight:600;color:var(--ink);}
.row{display:flex;align-items:center;gap:12px;}
.wrap{flex-wrap:wrap;}
.fade-in{animation:fadeUp .4s ease both;}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* responsive */
@media(max-width:900px){
  .cols-4{grid-template-columns:repeat(2,1fr);}
  .cols-3{grid-template-columns:repeat(2,1fr);}
  .hide-md{display:none !important;}
  .nav{display:none !important;}
}

/* ============================================================
   BOTTOM TAB BAR (≤900px)
   ============================================================ */
.bottom-nav{display:none;}
.bnav-item{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  background:none;border:none;color:var(--ink-500);
  font-family:var(--font-display);font-weight:600;font-size:.68rem;
  padding:4px 6px;min-width:52px;border-radius:var(--r-sm);
  transition:color .15s;cursor:pointer;
}
.bnav-item.active{color:var(--accent);}

@media(max-width:900px){
  .topbar{padding:10px 16px;gap:10px;}
  .topbar .brand img{height:36px;}
  .content{padding-bottom:90px;}
  .home-grid{grid-template-columns:1fr !important;}
  .home-grid>*{min-width:0;}
  .admin-grid{grid-template-columns:1fr !important;}
  .admin-grid>*{min-width:0;}
  .bottom-nav{
    display:flex;position:fixed;bottom:0;left:0;right:0;z-index:40;
    background:rgba(252,248,241,.96);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
    border-top:2.5px solid var(--cream-300);
    padding:6px 0 8px;
    justify-content:space-around;align-items:flex-start;
  }
}

/* ============================================================
   MOBILE (≤620px) — ไม่มี horizontal scroll
   ============================================================ */
@media(max-width:620px){
  /* ===== Core containment ===== */
  .shell{overflow-x:hidden;}
  .content{padding:16px 14px 100px;overflow-x:hidden;}
  .hide-sm{display:none !important;}

  /* ===== Login card: collapse to 1 col when left panel hidden ===== */
  .login-card{grid-template-columns:1fr !important;}

  /* ===== Hero: let text breathe closer to mascot ===== */
  .hero-content{max-width:calc(100% - 120px) !important;}
  .cols-2,.cols-3,.cols-4{grid-template-columns:1fr;}

  /* ===== Topbar ===== */
  .topbar{padding:8px 12px;gap:8px;}
  .topbar .brand img{height:32px;}

  /* ===== Cards ===== */
  .card,.card.flat{min-width:0;}
  .pad{padding:16px;}
  .pad-lg{padding:20px;}

  /* ===== Hero mascot ===== */
  .hero-mascot{width:110px !important;right:0 !important;bottom:-8px !important;}

  /* ===== Survey / reminder banner ===== */
  .survey-banner{flex-wrap:wrap;gap:10px !important;}
  .survey-banner .btn{width:100%;}

  /* ===== Section header rows (h3 + chip) ===== */
  .section-row{flex-wrap:wrap;gap:6px !important;}
  .section-row .chip{font-size:.75rem;}
  /* ===== Flex rows: ไม่ push width เกิน ===== */
  .row{min-width:0;max-width:100%;}
  .row>div,.row>span,.row>button{min-width:0;}
  .row .chip{flex-shrink:0;white-space:nowrap;}

  /* ===== Booking card (.bk) ===== */
  .bk{flex-wrap:wrap;gap:10px;padding:14px;}
  .bk .when{width:auto;border-right:none;border-bottom:2px dashed var(--cream-300);
    padding:0 0 10px;display:flex;gap:12px;align-items:center;}
  .bk .when .d{font-size:1.4rem;}

  /* ===== Stepper ===== */
  .stepper{gap:2px;margin-bottom:18px;}
  .step .bar{width:18px;margin:0 2px;}
  .step .num{width:32px;height:32px;font-size:.9rem;}

  /* ===== Date cards in strip ===== */
  .datecard{width:76px !important;padding:10px 4px;}
  .datecard .dnum{font-size:1.4rem;}

  /* ===== Time slots ===== */
  .slot{padding:16px 8px;}
  .slot .tm{font-size:1.3rem;}

  /* ===== Ranking podium ===== */
  .podium{grid-template-columns:repeat(3,1fr) !important;}
  .podium .card{padding:10px 4px !important;}
  .podium .avatar{width:40px !important;height:40px !important;}

  /* ===== Admin calendar ===== */
  .cal{gap:4px;}
  .cal-head{gap:4px;}
  .cell .dn{font-size:.95rem;}

  /* ===== Board ===== */
  .board{column-count:1;}

  /* ===== Bottom nav ===== */
  .bnav-item{min-width:44px;font-size:.62rem;}

  /* ===== Headings ===== */
  h1{font-size:1.5rem !important;}
  .section-title h2{font-size:1.3rem;}
}

/* tweak toggles */
.no-flowers .flower-decor{display:none !important;}
.no-bounce .mascot.bob{animation:none !important;}
.no-bounce .flower-decor{animation:none !important;}

/* ============================================================
   ADMIN CALENDAR
   ============================================================ */
.cal-head{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:8px;}
.cal-head div{text-align:center;font-family:var(--font-display);font-weight:600;color:var(--ink-500);font-size:.85rem;}
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;}
.cell{aspect-ratio:1/1;border:2px solid var(--cream-300);border-radius:var(--r-md);display:flex;flex-direction:column;
  align-items:center;justify-content:center;cursor:pointer;background:var(--paper);transition:.12s;position:relative;
  font-family:var(--font-display);}
.cell.empty{border:none;background:transparent;cursor:default;}
.cell .dn{font-weight:700;font-size:1.15rem;color:var(--ink);}
.cell .sub{font-size:.62rem;font-weight:600;color:var(--ink-400,var(--ink-500));margin-top:2px;}
.cell.past{opacity:.38;cursor:not-allowed;}
.cell.open{background:var(--accent);border-color:var(--ink);}
.cell.open .dn,.cell.open .sub{color:#fff;}
.cell:not(.open):not(.past):not(.empty):hover{border-color:var(--accent);transform:translateY(-2px);}
.cell.today{box-shadow:0 0 0 3px var(--gold);}
.cell .bdot{position:absolute;top:6px;right:7px;display:flex;gap:2px;}
.cell .bdot i{width:6px;height:6px;border-radius:50%;background:var(--gold);display:block;}
.cell.open .bdot i{background:#fff;}

.legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:16px;}
.legend span{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;color:var(--ink-500);}
.legend .sw{width:16px;height:16px;border-radius:5px;border:2px solid var(--ink);}

/* ============================================================
   POST-IT BOARD
   ============================================================ */
.board{column-count:3;column-gap:20px;}
.note{break-inside:avoid;margin:0 0 20px;border-radius:3px;padding:22px 20px 18px;position:relative;
  font-family:var(--font-body);color:#574536;box-shadow:3px 7px 16px -5px rgba(74,43,34,.4);
  transition:transform .15s, box-shadow .15s;}
.note:hover{transform:rotate(0deg) scale(1.02) !important;box-shadow:4px 10px 22px -6px rgba(74,43,34,.45);}
.note .pin{position:absolute;top:-9px;left:50%;transform:translateX(-50%);width:17px;height:17px;border-radius:50%;
  background:var(--accent);border:2px solid rgba(0,0,0,.12);box-shadow:0 2px 4px rgba(0,0,0,.3), inset 0 -2px 2px rgba(0,0,0,.15);}
.note .txt{font-size:1.06rem;line-height:1.5;white-space:pre-wrap;word-break:break-word;}
.note .by{margin-top:14px;font-family:var(--font-display);font-weight:700;font-size:.84rem;opacity:.62;}
.note.add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:140px;cursor:pointer;
  background:transparent;border:2.5px dashed var(--cream-300);box-shadow:none;color:var(--ink-500);text-align:center;}
.note.add:hover{border-color:var(--accent);color:var(--accent);transform:none !important;}
.swatches{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;}
.swatches button{width:34px;height:34px;border-radius:9px;border:2.5px solid transparent;cursor:pointer;transition:.12s;}
.swatches button.on{border-color:var(--ink);transform:scale(1.12);}

@media(max-width:900px){.board{column-count:2;}}
@media(max-width:600px){.board{column-count:1;}}

@media(max-width:620px){
  .cell .sub{display:none;}
}
