/* ============================================================
   iconsthai.css — Forest + Gold theme (Session A palette)
   Pages: index.asp / login.asp / demo.asp / contactus.asp /
          termservice.asp / private.asp
   Font: Prompt (UI) + Barlow Condensed (numerics) via Google Fonts
   Body class switches page mode:
     - default (no class) = Home / public landing
     - body.it-login  = Login (forest bg + centered card)
     - body.it-legal  = Terms / Privacy (cream bg + doc layout)
     - body.it-demo   = Demo (form + value props)
     - body.it-contact= Contact (info boxes + form)
   ============================================================ */
:root{
  /* ---- Forest + Gold palette (mirrors iconsthai-theme.css) ---- */
  --it-forest:       #0E4D2C;
  --it-forest-mid:   #1F8A3F;
  --it-forest-deep:  #082E1A;
  --it-gold:         #C9A961;
  --it-gold-mid:     #B5934A;
  --it-gold-light:   #E8D9B0;
  --it-cream:        #FAF8F3;
  --it-cream-2:      #F2EDE2;
  --it-cream-3:      #EEE9DA;
  --it-ink:          #1A1A1A;
  --it-ink-2:        #4A4A4A;
  --it-muted:        #6B6B6B;
  --it-muted-2:      #8B8B8B;
  --it-line:         #E5E2DA;
  --it-line-soft:    #EFECE3;
  --it-white:        #FFFFFF;
  --it-coral:        #C44536;
  --it-coral-soft:   #F6D9D4;

  /* ---- Status (kept for consistency) ---- */
  --it-success:      var(--it-forest-mid);
  --it-success-soft: #DDF3E1;

  /* ---- Shape ---- */
  --r:12px; --r-lg:18px; --r-pill:999px;

  /* ---- Font + width ---- */
  --ff:'Prompt',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --ff-num:'Barlow Condensed','Prompt',sans-serif;
  --maxw:1180px;
}

/* ---------------- Base ---------------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--ff);color:var(--it-ink);background:var(--it-cream);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
::selection{background:var(--it-gold-light)}
*{scrollbar-width:thin;scrollbar-color:#C9C5B5 transparent}
*::-webkit-scrollbar{width:9px;height:9px}
*::-webkit-scrollbar-thumb{background:#C9C5B5;border-radius:99px;border:2px solid transparent;background-clip:content-box}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------------- Buttons ---------------- */
.btn{display:inline-flex;align-items:center;gap:9px;height:48px;padding:0 24px;border-radius:var(--r-pill);font-weight:600;font-size:15px;transition:.16s;cursor:pointer;border:0;font-family:inherit;white-space:nowrap}
.btn-primary{background:var(--it-gold);color:var(--it-forest-deep);box-shadow:0 12px 26px -10px rgba(201,169,97,.55)}
.btn-primary:hover{background:var(--it-gold-mid);color:#fff;transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--it-forest);border:1px solid var(--it-gold-light)}
.btn-light:hover{transform:translateY(-2px);background:var(--it-cream-2);box-shadow:0 14px 30px -12px rgba(14,77,44,.25)}
.btn-ghost-d{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(232,217,176,.4)}
.btn-ghost-d:hover{background:rgba(232,217,176,.18);border-color:var(--it-gold)}
.btn-outline{background:#fff;color:var(--it-ink);border:1px solid var(--it-line)}
.btn-outline:hover{border-color:var(--it-gold);background:var(--it-cream-2)}

/* ---------------- Eyebrow / section head ---------------- */
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--it-forest);background:var(--it-gold-light);padding:6px 14px;border-radius:var(--r-pill)}
.sec{padding:84px 0}
.sec-head{max-width:680px;margin:0 auto 52px;text-align:center}
.sec-head h2{font-size:38px;line-height:1.2;font-weight:600;letter-spacing:-.5px;margin:16px 0 14px;color:var(--it-forest);text-wrap:balance;word-break:break-word}
.sec-head p{font-size:17px;color:var(--it-muted);margin:0;text-wrap:pretty}

/* ---------------- Nav (shared) ---------------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(250,248,243,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--it-line)}
.nav-in{display:flex;align-items:center;gap:30px;height:72px}
.nav .logo{display:flex;align-items:center;gap:12px;flex:0 0 auto}
.nav .logo .logo-img{height:42px;width:auto;display:block}
.nav .menu{display:flex;align-items:center;gap:4px;margin-left:8px}
.nav .menu a{padding:9px 14px;border-radius:8px;font-size:14.5px;font-weight:500;color:var(--it-ink-2);transition:.13s}
.nav .menu a:hover{background:var(--it-cream-2);color:var(--it-forest)}
.nav .spacer{flex:1 1 auto}
.nav .actions{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.nav .login-link{font-size:14.5px;font-weight:600;color:var(--it-ink-2);padding:9px 14px;border-radius:8px;transition:.13s}
.nav .login-link:hover{background:var(--it-cream-2);color:var(--it-forest)}
.nav .btn{height:44px;padding:0 20px;font-size:14.5px}
.nav .lang-toggle{display:inline-flex;background:var(--it-cream-2);border:1px solid var(--it-line);border-radius:var(--r-pill);padding:3px;font-size:12.5px;font-weight:600}
.nav .lang-toggle a{padding:4px 10px;border-radius:99px;color:var(--it-muted);transition:.13s}
.nav .lang-toggle a.on{background:#fff;color:var(--it-forest);box-shadow:0 1px 2px rgba(14,77,44,.08)}
@media(max-width:900px){.nav .menu{display:none}}

/* ---------------- HOME : Hero ---------------- */
.hero{position:relative;background:radial-gradient(1100px 560px at 78% -8%,rgba(201,169,97,.22),transparent 60%),linear-gradient(165deg,var(--it-forest) 0%,var(--it-forest-deep) 80%);color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(232,217,176,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(232,217,176,.06) 1px,transparent 1px);background-size:46px 46px;mask-image:radial-gradient(circle at 60% 30%,#000,transparent 75%);opacity:.6}
.hero-in{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding:90px 0 96px}
.hero .badge-line{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.08);border:1px solid rgba(232,217,176,.22);padding:7px 15px;border-radius:var(--r-pill);font-size:13.5px;font-weight:500;color:var(--it-gold-light);margin-bottom:24px}
.hero .badge-line .d{width:8px;height:8px;border-radius:50%;background:var(--it-gold);box-shadow:0 0 0 4px rgba(201,169,97,.25)}
.hero h1{font-size:52px;line-height:1.1;font-weight:700;letter-spacing:-1px;margin:0 0 22px;color:#fff;text-wrap:balance;word-break:break-word;overflow-wrap:anywhere}
.hero h1 .hl{color:var(--it-gold-light)}
.hero .lead{font-size:18.5px;line-height:1.65;color:#E5E2D5;margin:0 0 32px;max-width:560px;text-wrap:pretty}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:34px}
.hero .ticks{display:flex;flex-wrap:wrap;gap:9px 22px}
.hero .ticks span{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--it-gold-light);font-weight:400}
.hero .ticks svg{color:var(--it-gold);flex:0 0 auto}

/* hero mockup card */
.hero-card{background:linear-gradient(160deg,rgba(255,255,255,.1),rgba(255,255,255,.03));border:1px solid rgba(232,217,176,.2);border-radius:22px;padding:18px;backdrop-filter:blur(6px);box-shadow:0 40px 90px -30px rgba(0,0,0,.6)}
.hc-bar{display:flex;align-items:center;gap:7px;padding:4px 6px 14px}
.hc-bar i{width:11px;height:11px;border-radius:50%;background:rgba(255,255,255,.3)}
.hc-screen{background:#fff;border-radius:13px;overflow:hidden;color:var(--it-ink)}
.hc-top{display:flex;align-items:center;gap:10px;padding:13px 15px;border-bottom:1px solid var(--it-line)}
.hc-search{flex:1;height:32px;border-radius:99px;background:var(--it-cream);border:1px solid var(--it-line);display:flex;align-items:center;padding:0 12px;color:var(--it-muted);font-size:12.5px;gap:8px}
.hc-pill{font-size:11px;font-weight:600;color:var(--it-forest);background:var(--it-gold-light);border-radius:99px;padding:4px 10px}
.hc-rows{padding:8px 0}
.hc-row{display:flex;align-items:center;gap:12px;padding:11px 16px;border-bottom:1px solid var(--it-line-soft)}
.hc-row:last-child{border-bottom:0}
.hc-ic{width:34px;height:34px;border-radius:9px;background:var(--it-cream-2);color:var(--it-forest);display:grid;place-items:center;flex:0 0 auto}
.hc-tx{flex:1;min-width:0}
.hc-tx b{display:block;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hc-tx span{font-size:11.5px;color:var(--it-muted)}
.hc-chip{font-size:10.5px;font-weight:600;border-radius:99px;padding:3px 9px;white-space:nowrap}
.hc-chip.hot{background:var(--it-coral-soft);color:var(--it-coral)}
.hc-chip.warm{background:var(--it-gold-light);color:var(--it-gold-mid)}
.hc-chip.win{background:var(--it-success-soft);color:var(--it-forest)}
.hero-float{position:absolute;background:#fff;border-radius:14px;box-shadow:0 24px 50px -18px rgba(0,0,0,.45);padding:14px 16px;display:flex;align-items:center;gap:12px}
.hf-1{right:-14px;top:34px}
.hero-float .fi{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;color:#fff;flex:0 0 auto}
.hero-float .fv{font-family:var(--ff-num);font-size:22px;font-weight:700;line-height:1;color:var(--it-forest)}
.hero-float .fl{font-size:11.5px;color:var(--it-muted);margin-top:2px}
@media(max-width:920px){.hero-in{grid-template-columns:1fr;gap:40px;padding:64px 0 72px}.hero h1{font-size:40px}.hero-float{display:none}}

/* ---------------- HOME : Stat band ---------------- */
.band{background:var(--it-forest);color:#fff;padding:0}
.band-in{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(232,217,176,.18)}
.band .cell{background:var(--it-forest);padding:34px 24px;text-align:center}
.band .v{font-family:var(--ff-num);font-size:46px;font-weight:700;letter-spacing:-1px;color:var(--it-gold-light);line-height:1}
.band .l{font-size:14px;color:#D5D2C0;margin-top:8px;font-weight:400}
@media(max-width:760px){.band-in{grid-template-columns:repeat(2,1fr)}}

/* ---------------- HOME : Features grid ---------------- */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feat{background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg);padding:30px;transition:.18s}
.feat:hover{border-color:var(--it-gold);box-shadow:0 22px 48px -26px rgba(14,77,44,.25);transform:translateY(-3px)}
.feat .ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;color:#fff;margin-bottom:18px}
.feat h3{font-size:19px;font-weight:600;margin:0 0 9px;color:var(--it-forest)}
.feat p{font-size:14.5px;color:var(--it-muted);margin:0;line-height:1.65}
@media(max-width:880px){.feat-grid{grid-template-columns:1fr}}

/* ---------------- HOME : Categories ---------------- */
.cat-sec{background:var(--it-cream-2)}
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cat{display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--it-line);border-radius:var(--r);padding:16px 18px;transition:.15s}
.cat:hover{border-color:var(--it-gold);box-shadow:0 12px 26px -16px rgba(201,169,97,.4);transform:translateY(-2px)}
.cat .ci{width:42px;height:42px;border-radius:11px;background:var(--it-gold-light);color:var(--it-forest);display:grid;place-items:center;flex:0 0 auto}
.cat .cn{font-size:14.5px;font-weight:600;line-height:1.3;display:block;color:var(--it-ink)}
.cat .cc{font-size:12px;color:var(--it-muted)}
@media(max-width:880px){.cat-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------------- HOME : Steps ---------------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.step{position:relative;padding-top:8px}
.step .n{width:46px;height:46px;border-radius:13px;background:var(--it-forest);color:var(--it-gold-light);display:grid;place-items:center;font-family:var(--ff-num);font-size:22px;font-weight:700;margin-bottom:16px}
.step h3{font-size:18px;font-weight:600;margin:0 0 8px;color:var(--it-forest)}
.step p{font-size:14.5px;color:var(--it-muted);margin:0}
@media(max-width:880px){.steps{grid-template-columns:1fr;gap:20px}}

/* ---------------- HOME : Trust split ---------------- */
.trust{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.trust-list{display:flex;flex-direction:column;gap:18px;margin-top:6px}
.trust-item{display:flex;gap:14px}
.trust-item .ti{width:44px;height:44px;border-radius:12px;background:var(--it-gold-light);color:var(--it-forest);display:grid;place-items:center;flex:0 0 auto}
.trust-item h4{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--it-forest)}
.trust-item p{margin:0;font-size:14px;color:var(--it-muted);line-height:1.6}
.trust-visual{background:linear-gradient(160deg,var(--it-forest),var(--it-forest-deep));border-radius:22px;padding:38px;color:#fff;position:relative;overflow:hidden}
.trust-visual::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(232,217,176,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(232,217,176,.07) 1px,transparent 1px);background-size:38px 38px;opacity:.5}
.tv-row{position:relative;display:flex;align-items:center;gap:14px;padding:16px 0;border-bottom:1px solid rgba(232,217,176,.16)}
.tv-row:last-child{border-bottom:0}
.tv-row .tvi{width:46px;height:46px;border-radius:12px;background:rgba(232,217,176,.12);display:grid;place-items:center;color:var(--it-gold);flex:0 0 auto}
.tv-row b{font-size:16px;font-weight:600;display:block;color:#fff}
.tv-row span{font-size:13px;color:#D5D2C0}
@media(max-width:880px){.trust{grid-template-columns:1fr;gap:34px}}

/* ---------------- HOME : CTA ---------------- */
.cta-sec{position:relative;background:radial-gradient(800px 400px at 50% -20%,rgba(201,169,97,.3),transparent 65%),linear-gradient(160deg,var(--it-forest-mid),var(--it-forest-deep));color:#fff;text-align:center;overflow:hidden}
.cta-box{padding:80px 24px}
.cta-box h2{font-size:40px;font-weight:700;letter-spacing:-.5px;margin:0 0 16px;color:#fff;text-wrap:balance;word-break:break-word}
.cta-box p{font-size:18px;color:#E5E2D5;max-width:560px;margin:0 auto 32px}
.cta-box .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------------- Footer (shared) ---------------- */
.foot{background:var(--it-forest-deep);color:#D5D2C0;padding:64px 0 0}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px}
.foot .logo{display:inline-flex;align-items:center;gap:11px;margin-bottom:16px;background:#fff;border-radius:10px;padding:8px 14px;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.foot .logo .logo-img-foot{height:36px;width:auto;display:block}
.foot .about{font-size:14px;line-height:1.7;max-width:300px;margin:0 0 18px}
.foot .contact{display:flex;flex-direction:column;gap:8px;font-size:13.5px}
.foot .contact span{display:flex;align-items:flex-start;gap:9px}
.foot .contact svg{color:var(--it-gold);flex:0 0 auto;margin-top:3px}
.foot h5{color:var(--it-gold-light);font-size:13.5px;font-weight:600;margin:0 0 16px;letter-spacing:.6px;text-transform:uppercase}
.foot ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.foot ul a{font-size:14px;color:#D5D2C0;transition:.12s}
.foot ul a:hover{color:var(--it-gold)}
.foot-bottom{border-top:1px solid rgba(232,217,176,.14);padding:22px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px}
.foot-bottom .links{display:flex;gap:18px}
.foot-bottom .links a:hover{color:var(--it-gold)}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;gap:30px}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr}.sec{padding:60px 0}.sec-head h2,.cta-box h2{font-size:30px}}

/* =================================================================
   LOGIN page — body.it-login
   ================================================================= */
body.it-login{background:radial-gradient(900px 500px at 12% -5%,rgba(201,169,97,.22),transparent 60%),linear-gradient(165deg,var(--it-forest),var(--it-forest-deep));min-height:100vh;display:flex;flex-direction:column;font-size:15px;color:#fff}
body.it-login::before{content:"";position:fixed;inset:0;background-image:linear-gradient(rgba(232,217,176,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(232,217,176,.05) 1px,transparent 1px);background-size:46px 46px;mask-image:radial-gradient(circle at 30% 20%,#000,transparent 70%);pointer-events:none;z-index:0}
body.it-login .nav{display:none}
.login-wrap{flex:1 1 auto;display:flex;align-items:center;justify-content:center;padding:14px 16px;position:relative;z-index:1}
.login-card{width:100%;max-width:1000px;background:#fff;border-radius:22px;overflow:hidden;box-shadow:0 50px 110px -30px rgba(0,0,0,.55);display:grid;grid-template-columns:1.1fr .9fr;color:var(--it-ink)}
@media(max-width:860px){.login-card{grid-template-columns:1fr;max-width:480px}}

/* terms panel */
.lc-left{background:linear-gradient(165deg,var(--it-cream),var(--it-cream-2));color:var(--it-ink);padding:22px 28px 24px;position:relative;overflow:hidden;border-right:1px solid var(--it-line)}
.lc-left::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(14,77,44,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(14,77,44,.04) 1px,transparent 1px);background-size:38px 38px;opacity:.6}
.lc-left .inner{position:relative}
.lc-brand{display:flex;align-items:center;margin-bottom:12px}
.lc-brand img{height:40px}
.lc-intro{font-size:13.5px;line-height:1.6;color:var(--it-ink-2);background:#fff;border:1px solid var(--it-line);border-radius:var(--r);padding:11px 14px;margin-bottom:14px;text-wrap:pretty}
.terms-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--it-forest);margin-bottom:10px}
.terms-title .ti{width:24px;height:24px;border-radius:7px;background:var(--it-gold-light);color:var(--it-forest);display:grid;place-items:center;flex:0 0 auto}
.terms{display:flex;flex-direction:column;gap:7px}
.term{display:flex;gap:11px;background:#fff;border:1px solid var(--it-line);border-radius:9px;padding:8px 12px}
.term .num{width:23px;height:23px;border-radius:50%;background:#fff;border:1.5px solid var(--it-gold);color:var(--it-gold-mid);display:grid;place-items:center;font-size:11.5px;font-weight:700;flex:0 0 auto;margin-top:1px;font-family:var(--ff-num)}
.term p{margin:0;font-size:12.5px;line-height:1.5;color:var(--it-ink-2)}
.term p b{color:var(--it-ink);font-weight:600}
.term.hl p b{color:var(--it-forest)}

/* form panel */
.lc-right{padding:26px 32px 24px;display:flex;flex-direction:column}
.lc-h{font-size:22px;font-weight:600;letter-spacing:-.4px;margin:0 0 4px;color:var(--it-forest)}
.lc-sub{font-size:13.5px;color:var(--it-muted);margin:0 0 18px}
.field{margin-bottom:12px}
.field label{display:block;font-size:12.5px;font-weight:500;color:var(--it-ink-2);margin-bottom:6px}
.input-wrap{position:relative}
.input-wrap .ic{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--it-muted)}
.input-wrap input{width:100%;height:46px;border:1px solid var(--it-line);border-radius:var(--r);background:var(--it-cream);padding:0 16px 0 42px;font-family:inherit;font-size:14.5px;color:var(--it-ink);outline:none;transition:.15s}
.input-wrap input::placeholder{color:var(--it-muted-2)}
.input-wrap input:focus{background:#fff;border-color:var(--it-gold);box-shadow:0 0 0 3px var(--it-gold-light)}

.btn-otp{width:100%;height:48px;border-radius:var(--r);background:var(--it-gold);color:var(--it-forest-deep);font-weight:600;font-size:15px;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:.15s;box-shadow:0 14px 28px -12px rgba(201,169,97,.55);margin-top:4px}
.btn-otp:hover{background:var(--it-gold-mid);color:#fff;transform:translateY(-2px)}
.btn-otp:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.btn-back{width:100%;height:42px;border-radius:var(--r);background:var(--it-cream-2);color:var(--it-ink-2);font-weight:500;font-size:13.5px;border:1px solid var(--it-line);margin-top:9px;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:.13s}
.btn-back:hover{background:var(--it-cream-3)}

.lc-foot-note{margin-top:auto;padding-top:16px;font-size:11.5px;color:var(--it-muted);line-height:1.6}
.lc-foot-note .lk{color:var(--it-forest);font-weight:600}

/* OTP step */
.otp-info{font-size:13px;color:var(--it-ink-2);margin:0 0 4px}
.otp-info b{font-weight:600;color:var(--it-ink)}
.otp-edit{font-size:12px;color:var(--it-forest);font-weight:600;margin-bottom:14px;display:inline-flex;align-items:center;gap:5px;cursor:pointer}
.otp-boxes{display:flex;gap:8px;margin-bottom:14px;justify-content:center}
.otp-boxes input{width:46px;height:52px;flex:0 0 46px;text-align:center;font-size:22px;font-weight:700;color:var(--it-forest);border:1.5px solid var(--it-line);border-radius:10px;background:var(--it-cream);outline:none;transition:.14s;font-family:var(--ff-num);padding:0}
@media(max-width:380px){.otp-boxes input{width:40px;flex:0 0 40px;height:48px;font-size:20px}.otp-boxes{gap:6px}}
.otp-boxes input:focus{border-color:var(--it-gold);background:#fff;box-shadow:0 0 0 3px var(--it-gold-light)}
.otp-boxes input.filled{border-color:var(--it-gold);background:#fff}
.otp-resend{font-size:13px;color:var(--it-muted);text-align:center;margin-top:4px}
.otp-resend b{color:var(--it-ink-2);font-variant-numeric:tabular-nums}
.otp-resend button{color:var(--it-forest);font-weight:600;font-size:13px}
.otp-resend button:disabled{color:var(--it-muted);cursor:not-allowed;font-weight:500}

.sent-toast{display:flex;align-items:center;gap:9px;background:var(--it-success-soft);color:var(--it-forest);border-radius:10px;padding:9px 13px;font-size:12.5px;font-weight:600;margin-bottom:12px}

.login-foot{position:relative;z-index:1;text-align:center;color:#D5D2C0;font-size:12px;padding:0 20px 14px}
.login-foot a{color:var(--it-gold-light);font-weight:500}
.login-foot .sep{margin:0 9px;opacity:.5}

/* ---- OTP entry page (login_phoneotp.asp) ---- */
.otp-card{width:100%;max-width:460px;background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 50px 110px -30px rgba(0,0,0,.55);color:var(--it-ink);padding:24px 28px 22px;position:relative;z-index:1}
.otp-brand{display:flex;justify-content:center;margin-bottom:10px}
.otp-brand img{height:36px}
.otp-h{font-size:21px;font-weight:600;letter-spacing:-.3px;margin:0 0 4px;color:var(--it-forest);text-align:center}
.otp-sub{font-size:13px;color:var(--it-muted);margin:0 0 12px;text-align:center}

/* Login info panel */
.otp-info-panel{background:var(--it-cream-2);border:1px solid var(--it-line);border-radius:10px;padding:9px 13px;margin-bottom:12px;display:grid;grid-template-columns:auto 1fr;gap:5px 14px;font-size:12.5px;align-items:center}
.otp-info-panel .ip-l{color:var(--it-muted);font-weight:500}
.otp-info-panel .ip-v{color:var(--it-ink);font-weight:600;word-break:break-word}
.otp-info-panel .ip-v .num{font-family:var(--ff-num);letter-spacing:.5px}

/* Wrong / lock banners */
.otp-banner{display:flex;align-items:center;gap:9px;border-radius:10px;padding:9px 13px;font-size:13px;font-weight:600;margin-bottom:12px}
.otp-banner.err{background:var(--it-coral-soft);color:var(--it-coral)}
.otp-banner.lock{background:#FBEFEC;color:#9E3225;border:1px solid #F2D2CB}
.otp-banner.warn{background:#FEF6E0;color:#7A5A18;border:1px solid #E8D9B0}
.otp-banner .countdown-mini{margin-left:auto;font-family:var(--ff-num);font-size:14px;letter-spacing:.5px}

/* Shake on wrong code */
@keyframes shakeX{
  0%,100%{transform:translateX(0)}
  20%,60%{transform:translateX(-7px)}
  40%,80%{transform:translateX(7px)}
}
.otp-boxes.shake input{border-color:var(--it-coral);background:#fff;animation:shakeX .42s cubic-bezier(.36,.07,.19,.97) both}
.otp-boxes.locked input{background:#F5F2EA;color:var(--it-muted);cursor:not-allowed;pointer-events:none}
.btn-otp.locked{background:#D9D3C0;color:#8B8467;box-shadow:none;cursor:not-allowed;pointer-events:none}

/* Countdown */
.otp-timer{display:flex;align-items:center;justify-content:center;gap:7px;font-size:13px;color:var(--it-muted);margin:8px 0 8px}
.otp-timer.expired{color:var(--it-coral);font-weight:600}
.otp-timer .clock-num{font-family:var(--ff-num);font-weight:700;font-size:15px;color:var(--it-forest);letter-spacing:.5px}
.otp-timer.expired .clock-num{color:var(--it-coral)}

/* Resend */
.otp-resend-area{text-align:center;font-size:13px;color:var(--it-muted);margin-top:8px;padding-top:10px;border-top:1px solid var(--it-line-soft)}
.otp-resend-area button,.otp-resend-area a{color:var(--it-forest);font-weight:600;font-size:13px;background:none;border:0;cursor:pointer;font-family:inherit}
.otp-resend-area button:disabled{color:var(--it-muted);cursor:not-allowed;font-weight:500}
.otp-resend-area .resend-help{display:block;font-size:11.5px;color:var(--it-muted-2);margin-top:3px}

/* Back link */
.otp-back{display:flex;align-items:center;justify-content:center;gap:6px;font-size:12.5px;color:var(--it-muted);margin-top:12px}
.otp-back a{color:var(--it-forest);font-weight:600}
.otp-back a:hover{text-decoration:underline}

/* =================================================================
   LEGAL pages (Terms / Privacy) — body.it-legal
   ================================================================= */
body.it-legal{background:var(--it-cream);font-size:15.5px;line-height:1.7}
.legal-hero{position:relative;background:radial-gradient(800px 360px at 85% -20%,rgba(201,169,97,.22),transparent 60%),linear-gradient(160deg,var(--it-forest),var(--it-forest-deep));color:#fff;overflow:hidden}
.legal-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(232,217,176,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(232,217,176,.05) 1px,transparent 1px);background-size:44px 44px;mask-image:radial-gradient(circle at 70% 30%,#000,transparent 75%);opacity:.6}
.legal-hero-in{position:relative;padding:56px 0 60px}
.lh-crumb{display:flex;align-items:center;gap:8px;font-size:13px;color:#C5C3B0;margin-bottom:18px}
.lh-crumb a:hover{color:var(--it-gold)}
.lh-crumb .sep{opacity:.5}
.lh-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(232,217,176,.1);border:1px solid rgba(232,217,176,.22);padding:6px 14px;border-radius:var(--r-pill);font-size:13px;font-weight:500;color:var(--it-gold-light);margin-bottom:18px}
.legal-hero h1{font-size:40px;line-height:1.2;font-weight:700;letter-spacing:-.6px;margin:0 0 14px;color:#fff;text-wrap:balance}
.legal-hero p{font-size:16.5px;color:#D5D2C0;margin:0;max-width:680px;text-wrap:pretty}
.lh-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.lh-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(232,217,176,.08);border:1px solid rgba(232,217,176,.2);border-radius:var(--r-pill);padding:7px 15px;font-size:13px;font-weight:500;color:var(--it-gold-light)}
.lh-tag svg{color:var(--it-gold)}
.lh-switch{display:inline-flex;background:rgba(232,217,176,.08);border:1px solid rgba(232,217,176,.22);border-radius:var(--r-pill);padding:3px;margin-top:24px}
.lh-switch a{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 18px;border-radius:var(--r-pill);font-size:13.5px;font-weight:600;color:#D5D2C0;transition:.14s}
.lh-switch a.on{background:var(--it-gold);color:var(--it-forest-deep)}
.lh-switch a:not(.on):hover{color:#fff}

/* doc layout */
.doc{display:grid;grid-template-columns:280px minmax(0,1fr);gap:40px;align-items:start;padding:44px 0 72px}
@media(max-width:920px){.doc{grid-template-columns:1fr;gap:24px}}
.toc{position:sticky;top:88px;background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg);padding:20px;box-shadow:0 1px 2px rgba(14,77,44,.05)}
@media(max-width:920px){.toc{position:static}}
.toc-t{font-size:11.5px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--it-muted);margin:0 0 14px;display:flex;align-items:center;gap:8px}
.toc ol{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1px;max-height:65vh;overflow-y:auto}
.toc li a{display:flex;gap:10px;padding:8px 10px;border-radius:8px;font-size:13.5px;font-weight:400;color:var(--it-ink-2);transition:.12s;line-height:1.4}
.toc li a:hover{background:var(--it-cream-2);color:var(--it-forest)}
.toc li a.active{background:var(--it-gold-light);color:var(--it-forest);font-weight:600}
.toc li a .tn{flex:0 0 auto;min-width:20px;height:20px;border-radius:6px;background:var(--it-cream-2);color:var(--it-muted);font-size:11px;font-weight:700;display:grid;place-items:center;margin-top:1px;font-family:var(--ff-num)}
.toc li a.active .tn{background:var(--it-gold);color:var(--it-forest-deep)}

.doc-body{background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg);padding:14px 44px 40px;box-shadow:0 1px 2px rgba(14,77,44,.05)}
@media(max-width:560px){.doc-body{padding:10px 22px 30px}}
.intro-note{display:flex;gap:13px;background:var(--it-cream-2);border:1px solid var(--it-line);border-radius:var(--r);padding:16px 18px;margin:28px 0 8px}
.intro-note svg{color:var(--it-forest);flex:0 0 auto;margin-top:2px}
.intro-note p{margin:0;font-size:14.5px;color:var(--it-ink-2);line-height:1.7}

.doc-sec{padding:30px 0 4px;scroll-margin-top:84px;border-top:1px solid var(--it-line-soft)}
.doc-sec:first-of-type{border-top:0}
.doc-sec-h{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}
.doc-sec-h .sn{flex:0 0 auto;width:38px;height:38px;border-radius:11px;background:linear-gradient(150deg,var(--it-forest),var(--it-forest-mid));color:var(--it-gold-light);display:grid;place-items:center;font-family:var(--ff-num);font-size:17px;font-weight:700;box-shadow:0 8px 16px -8px rgba(14,77,44,.5)}
.doc-sec-h h2{margin:0;font-size:21px;font-weight:600;letter-spacing:-.3px;line-height:1.3;padding-top:5px;color:var(--it-forest)}
.doc-sec-body{padding-left:52px}
@media(max-width:560px){.doc-sec-body{padding-left:0}}
.doc-sec-body p{margin:0 0 14px;color:var(--it-ink-2);font-size:15px;line-height:1.8;text-wrap:pretty}
.doc-sec-body p strong,.doc-sec-body p b{color:var(--it-ink);font-weight:600}
.sub-h{font-size:15.5px;font-weight:600;color:var(--it-forest);margin:20px 0 10px;display:flex;align-items:center;gap:9px}
.sub-h .dot{width:7px;height:7px;border-radius:2px;background:var(--it-gold);flex:0 0 auto}

ul.rules{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-direction:column;gap:9px}
ul.rules li{position:relative;padding:11px 14px 11px 40px;background:var(--it-cream-2);border:1px solid var(--it-line-soft);border-radius:10px;font-size:14px;color:var(--it-ink-2);line-height:1.65}
ul.rules li::before{content:"";position:absolute;left:15px;top:17px;width:7px;height:7px;border-radius:50%;background:var(--it-gold);box-shadow:0 0 0 3px var(--it-gold-light)}
ul.rules li b{color:var(--it-ink);font-weight:600}
ul.rules.warn li::before{background:var(--it-coral);box-shadow:0 0 0 3px var(--it-coral-soft)}

.callout{border-radius:var(--r-lg);padding:20px 22px;margin:8px 0 18px;border:1px solid;display:flex;gap:14px}
.callout svg{flex:0 0 auto;margin-top:2px}
.callout .ct h4{margin:0 0 6px;font-size:15.5px;font-weight:600}
.callout .ct p{margin:0;font-size:14px;line-height:1.7}
.callout.danger{background:#FBEFEC;border-color:#F2D2CB}
.callout.danger svg{color:var(--it-coral)}
.callout.danger h4{color:#9E3225}
.callout.danger p{color:#6D2E25}
.callout.info{background:var(--it-gold-light);border-color:#D9C580}
.callout.info svg{color:var(--it-forest)}
.callout.info h4{color:var(--it-forest)}
.callout.info p{color:#3D4631}

ol.numlist{margin:6px 0 16px;padding-left:0;list-style:none;counter-reset:nl;display:flex;flex-direction:column;gap:8px}
ol.numlist li{position:relative;padding:9px 14px 9px 42px;font-size:14px;color:var(--it-ink-2);line-height:1.65;background:#fff;border:1px solid var(--it-line);border-radius:9px;counter-increment:nl}
ol.numlist li::before{content:"("counter(nl)")";position:absolute;left:12px;top:9px;font-weight:700;color:var(--it-gold-mid);font-size:13px;font-family:var(--ff-num)}

.def-grid{display:flex;flex-direction:column;gap:0;border:1px solid var(--it-line);border-radius:var(--r);overflow:hidden;margin-bottom:8px}
.def-row{display:grid;grid-template-columns:200px 1fr;gap:0}
.def-row:not(:last-child){border-bottom:1px solid var(--it-line-soft)}
.def-row dt{background:var(--it-cream-2);padding:11px 16px;font-size:13.5px;font-weight:600;color:var(--it-forest);margin:0;border-right:1px solid var(--it-line-soft)}
.def-row dd{padding:11px 16px;font-size:14px;color:var(--it-ink-2);margin:0;line-height:1.6}
@media(max-width:560px){.def-row{grid-template-columns:1fr}.def-row dt{border-right:0;border-bottom:1px solid var(--it-line-soft)}}

.doc-foot-note{margin-top:28px;padding-top:20px;border-top:1px solid var(--it-line);font-size:13px;color:var(--it-muted);display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.doc-foot-note .v{font-weight:600;color:var(--it-ink-2)}
.backtop{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--it-forest)}

.contact-card{display:flex;gap:16px;align-items:flex-start;background:linear-gradient(150deg,var(--it-cream-2),var(--it-cream-3));border:1px solid var(--it-line);border-radius:var(--r-lg);padding:22px;margin-top:24px}
.contact-card .ci{width:46px;height:46px;border-radius:12px;background:#fff;border:1px solid var(--it-line);color:var(--it-forest);display:grid;place-items:center;flex:0 0 auto}
.contact-card h4{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--it-forest)}
.contact-card p{margin:0;font-size:13.5px;color:var(--it-ink-2);line-height:1.7}
.contact-card a{color:var(--it-forest);font-weight:600}

@media(max-width:520px){.legal-hero h1{font-size:30px}}

/* =================================================================
   DEMO page — body.it-demo
   ================================================================= */
body.it-demo{background:var(--it-cream);font-size:15px;line-height:1.65}

.demo-hero{position:relative;background:radial-gradient(800px 380px at 88% -20%,rgba(201,169,97,.22),transparent 60%),linear-gradient(160deg,var(--it-forest),var(--it-forest-deep));color:#fff;overflow:hidden}
.demo-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(232,217,176,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(232,217,176,.05) 1px,transparent 1px);background-size:44px 44px;mask-image:radial-gradient(circle at 75% 25%,#000,transparent 72%);opacity:.6}
.demo-grid{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;padding:54px 0 64px}
@media(max-width:920px){.demo-grid{grid-template-columns:1fr;gap:32px;padding:40px 0 48px}}
.demo-left{color:#fff;position:sticky;top:90px}
@media(max-width:920px){.demo-left{position:static}}
.demo-left .crumb{display:flex;align-items:center;gap:8px;font-size:13px;color:#C5C3B0;margin-bottom:18px}
.demo-left .crumb a:hover{color:var(--it-gold)}
.demo-left .crumb .sep{opacity:.5}
.demo-left .dh-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(232,217,176,.1);border:1px solid rgba(232,217,176,.22);padding:6px 14px;border-radius:var(--r-pill);font-size:13px;font-weight:500;color:var(--it-gold-light);margin-bottom:18px}
.demo-left h1{font-size:38px;line-height:1.2;font-weight:700;letter-spacing:-.6px;margin:0 0 14px;color:#fff;text-wrap:balance}
.demo-left .lead{font-size:16px;color:#D5D2C0;margin:0 0 26px;text-wrap:pretty}
.benefits{display:flex;flex-direction:column;gap:14px;margin-bottom:26px}
.benefit{display:flex;gap:13px;align-items:flex-start}
.benefit .bi{width:40px;height:40px;border-radius:11px;background:rgba(232,217,176,.1);border:1px solid rgba(232,217,176,.2);color:var(--it-gold);display:grid;place-items:center;flex:0 0 auto}
.benefit h4{margin:0 0 2px;font-size:15px;font-weight:600;color:#fff}
.benefit p{margin:0;font-size:13.5px;color:#C5C3B0;line-height:1.6}
.assure{display:flex;flex-wrap:wrap;gap:9px}
.assure span{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--it-gold-light);background:rgba(232,217,176,.08);border:1px solid rgba(232,217,176,.18);border-radius:var(--r-pill);padding:7px 14px}
.assure svg{color:var(--it-gold)}

.form-card{background:#fff;border-radius:var(--r-lg);box-shadow:0 40px 90px -30px rgba(0,0,0,.45);overflow:hidden;color:var(--it-ink)}
.fc-head{padding:24px 28px 20px;border-bottom:1px solid var(--it-line);background:linear-gradient(160deg,#fff,var(--it-cream-2))}
.fc-head h2{margin:0 0 5px;font-size:20px;font-weight:600;letter-spacing:-.3px;color:var(--it-forest)}
.fc-head p{margin:0;font-size:13.5px;color:var(--it-muted)}
.fc-body{padding:24px 28px}
@media(max-width:520px){.fc-head,.fc-body{padding-left:20px;padding-right:20px}}

.grp-label{display:flex;align-items:center;gap:8px;font-size:11.5px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--it-muted);margin:6px 0 14px}
.grp-label:not(:first-child){margin-top:26px;padding-top:22px;border-top:1px solid var(--it-line-soft)}
.grp-label .gn{width:20px;height:20px;border-radius:6px;background:var(--it-gold-light);color:var(--it-forest);font-size:11px;font-weight:700;display:grid;place-items:center;font-family:var(--ff-num)}

.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fgrid .full{grid-column:1/-1}
@media(max-width:520px){.fgrid{grid-template-columns:1fr}}

.dm-field{margin-bottom:0}
.dm-field label{display:block;font-size:13px;font-weight:500;color:var(--it-ink-2);margin-bottom:7px}
.dm-field label .req{color:var(--it-coral);margin-left:3px}
.dm-field label .opt{color:var(--it-muted);font-weight:400;font-size:12px;margin-left:4px}
.ctrl{position:relative}
.ctrl .ic{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--it-muted);pointer-events:none}
.ctrl input,.ctrl textarea,.ctrl select{width:100%;border:1px solid var(--it-line);border-radius:10px;background:var(--it-cream);font-family:inherit;font-size:14px;color:var(--it-ink);outline:none;transition:.15s}
.ctrl input,.ctrl select{height:46px;padding:0 14px}
.ctrl.has-ic input{padding-left:40px}
.ctrl textarea{padding:12px 14px;min-height:90px;resize:vertical;line-height:1.6}
.ctrl input::placeholder,.ctrl textarea::placeholder{color:var(--it-muted-2)}
.ctrl input:focus,.ctrl textarea:focus,.ctrl select:focus{background:#fff;border-color:var(--it-gold);box-shadow:0 0 0 3px var(--it-gold-light)}
.dm-field.err .ctrl input,.dm-field.err .ctrl textarea,.dm-field.err .ctrl select{border-color:var(--it-coral);background:#fff;box-shadow:0 0 0 3px var(--it-coral-soft)}
.dm-err-msg{font-size:12px;color:var(--it-coral);font-weight:600;margin-top:5px;display:flex;align-items:center;gap:5px}

.consent{display:flex;gap:11px;align-items:flex-start;margin-top:22px;padding:14px 16px;background:var(--it-cream-2);border:1px solid var(--it-line);border-radius:10px;cursor:pointer}
.consent .box{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--it-muted);display:grid;place-items:center;flex:0 0 auto;transition:.12s;margin-top:1px;background:#fff}
.consent.on .box{background:var(--it-gold);border-color:var(--it-gold);color:var(--it-forest-deep)}
.consent .box svg{opacity:0;transition:.12s}
.consent.on .box svg{opacity:1}
.consent p{margin:0;font-size:12.8px;color:var(--it-ink-2);line-height:1.6}
.consent a{color:var(--it-forest);font-weight:600}
.dm-field.err .consent{border-color:var(--it-coral);background:#fff}

.submit-btn{width:100%;height:52px;border-radius:12px;background:var(--it-gold);color:var(--it-forest-deep);font-weight:600;font-size:16px;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:.15s;margin-top:20px;box-shadow:0 16px 30px -12px rgba(201,169,97,.55)}
.submit-btn:hover{background:var(--it-gold-mid);color:#fff;transform:translateY(-2px)}
.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.form-note{text-align:center;font-size:12px;color:var(--it-muted);margin-top:14px;line-height:1.65}
.form-note a{color:var(--it-forest);font-weight:600}

.success{padding:50px 30px 46px;text-align:center;max-width:560px;margin:0 auto}
.success .badge{width:88px;height:88px;border-radius:50%;background:var(--it-success-soft);color:var(--it-forest);display:grid;place-items:center;margin:0 auto 22px;animation:pop .4s cubic-bezier(.3,1.4,.5,1) both}
@keyframes pop{from{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}
.success h2{margin:0 0 10px;font-size:26px;font-weight:600;letter-spacing:-.4px;color:var(--it-forest)}
.success>p{margin:0 0 26px;font-size:15.5px;color:var(--it-ink-2);line-height:1.7;text-wrap:pretty}
.recap{text-align:left;background:var(--it-cream-2);border:1px solid var(--it-line);border-radius:var(--r);padding:18px 20px;margin-bottom:24px}
.recap .rt{font-size:11.5px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--it-muted);margin-bottom:12px}
.recap dl{margin:0;display:grid;grid-template-columns:140px 1fr;gap:9px 14px}
.recap dt{font-size:13px;color:var(--it-muted);font-weight:400}
.recap dd{margin:0;font-size:13.5px;color:var(--it-ink);font-weight:500;word-break:break-word}
.success .nextsteps{display:flex;flex-direction:column;gap:10px;text-align:left;margin-bottom:26px}
.nextstep{display:flex;gap:12px;align-items:center;font-size:13.5px;color:var(--it-ink-2)}
.nextstep .ni{width:30px;height:30px;border-radius:9px;background:var(--it-gold-light);color:var(--it-forest);display:grid;place-items:center;flex:0 0 auto}
.success .row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-solid{display:inline-flex;align-items:center;gap:8px;height:48px;padding:0 22px;border-radius:var(--r-pill);background:var(--it-gold);color:var(--it-forest-deep);font-weight:600;font-size:14.5px;transition:.15s}
.btn-solid:hover{background:var(--it-gold-mid);color:#fff}

@media(max-width:560px){.demo-left h1{font-size:30px}.recap dl{grid-template-columns:1fr;gap:4px}.recap dt{margin-top:8px}}

/* =================================================================
   CONTACT US page — body.it-contact
   ================================================================= */
body.it-contact{background:var(--it-cream);font-size:15px;line-height:1.65}

/* =================================================================
   INTERNAL APP (post-login) - body.it-app
   firmmain.asp, firmdetail.asp, firmsearch.asp, etc.
   Layout: full-height shell, top bar + sidebar (forest) + main
   ================================================================= */
body.it-app{margin:0;background:var(--it-cream-2);font-size:14px;line-height:1.45;color:var(--it-ink);min-height:100vh}
body.it-app .nav,body.it-app .foot{display:none}
.app{min-height:100vh;display:flex;flex-direction:column}

/* ---------------- App top bar (sticky) ---------------- */
.appbar{height:60px;flex:0 0 auto;background:#fff;border-bottom:1px solid var(--it-line);display:flex;align-items:center;gap:18px;padding:0 18px;position:sticky;top:0;z-index:30}
.appbar .brand{display:flex;align-items:center;flex:0 0 auto;width:264px}
.appbar .brand img{height:32px;display:block}
.appbar .brand .vline{width:1px;height:28px;background:var(--it-line);margin:0 14px}
/* Brand tagline — stacks bold name on its own (allowed to wrap to 2 Thai lines)
   then the partner line beneath. Partner line forced single-line so "partner"
   doesn't drop on narrow widths. */
.appbar .brand .tagline{font-size:11px;color:var(--it-muted);line-height:1.25;display:block}
.appbar .brand .tagline b{display:block;color:var(--it-ink-2);font-weight:600;font-size:12px}
.appbar .brand .tagline em{display:block;font-style:normal;font-size:9.5px;color:var(--it-muted-2);font-weight:400;letter-spacing:.2px;white-space:nowrap;margin-top:1px}

.app-search{flex:1 1 auto;max-width:560px;position:relative}
.app-search .ic{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--it-muted)}
.app-search input{width:100%;height:38px;border-radius:var(--r-pill);border:1px solid var(--it-line);background:var(--it-cream-2);padding:0 16px 0 40px;font-size:13.5px;color:var(--it-ink);outline:none;font-family:inherit;transition:.16s}
.app-search input::placeholder{color:var(--it-muted-2)}
.app-search input:focus{background:#fff;border-color:var(--it-gold);box-shadow:0 0 0 3px var(--it-gold-light)}
.app-search .kbd{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--it-muted);border:1px solid var(--it-line);border-radius:5px;padding:1px 6px;background:#fff;font-weight:600}
.app-search .search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);height:26px;padding:0 12px;border-radius:99px;font-size:12px;font-weight:600;color:var(--it-forest);background:var(--it-gold-light);border:1px solid var(--it-gold);cursor:pointer;font-family:inherit;transition:.13s}
.app-search .search-clear:hover{background:var(--it-gold);color:var(--it-forest-deep)}

.app-spacer{flex:1 1 auto}
.app-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto}
.iconbtn{width:38px;height:38px;border-radius:8px;display:grid;place-items:center;color:var(--it-ink-2);position:relative;transition:.14s;background:none;border:0;cursor:pointer;text-decoration:none}
.iconbtn:hover{background:var(--it-cream-2);color:var(--it-forest)}
.iconbtn .badge{position:absolute;top:5px;right:5px;min-width:16px;height:16px;padding:0 4px;border-radius:99px;background:var(--it-coral);color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center;border:2px solid #fff}
.iconbtn .badge.gold{background:var(--it-gold);color:var(--it-forest-deep)}
.iconbtn.has-fav{color:var(--it-gold);background:rgba(201,169,97,.12)}
.iconbtn.has-fav:hover{background:rgba(201,169,97,.22);color:var(--it-gold-mid)}
.iconbtn.has-fav svg path{fill:var(--it-gold);stroke:var(--it-gold)}

.member{display:flex;align-items:center;gap:10px;height:38px;padding:0 6px 0 13px;border:1px solid var(--it-line);border-radius:var(--r-pill);background:var(--it-cream-2)}
.member .lbl{font-size:11px;color:var(--it-muted);line-height:1.15}
.member .lbl b{display:block;color:var(--it-ink-2);font-weight:600;font-size:12px}
.member .days{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:48px;height:28px;border-radius:var(--r-pill);background:var(--it-success-soft);color:var(--it-forest);font-weight:700;line-height:1}
.member .days .n{font-size:14px;font-family:var(--ff-num)}
.member .days .u{font-size:9px;font-weight:600;opacity:.8}
.member.warn .days{background:var(--it-coral-soft);color:var(--it-coral)}

.langtog{display:flex;border:1px solid var(--it-line);border-radius:var(--r-pill);overflow:hidden;height:34px;background:var(--it-cream-2)}
.langtog a,.langtog button{padding:0 12px;font-size:12px;font-weight:600;color:var(--it-muted);display:flex;align-items:center;background:none;border:0;cursor:pointer;font-family:inherit;text-decoration:none}
.langtog .on{background:var(--it-forest);color:var(--it-gold-light)}

.user{display:flex;align-items:center;gap:9px;padding:4px 6px 4px 4px;border-radius:var(--r-pill);transition:.14s;background:none;border:0;cursor:pointer;font-family:inherit}
.user:hover{background:var(--it-cream-2)}
.user .av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--it-forest),var(--it-forest-mid));color:var(--it-gold-light);display:grid;place-items:center;font-weight:700;font-size:13px}
.user .nm{font-size:12.5px;font-weight:600;line-height:1.15;text-align:left}
.user .nm small{display:block;font-weight:500;color:var(--it-muted);font-size:10.5px}

/* ---------------- App body ---------------- */
.app-body{flex:1 1 auto;display:flex;align-items:flex-start}

/* ---------------- Sidebar (forest gradient, sticky) ---------------- */
.sidebar{width:284px;flex:0 0 auto;background:linear-gradient(190deg,var(--it-forest),var(--it-forest-deep));color:#D5D2C0;display:flex;flex-direction:column;position:sticky;top:60px;height:calc(100vh - 60px)}
.side-scroll{flex:1 1 auto;overflow-y:auto;padding:12px 12px 18px}
.side-scroll::-webkit-scrollbar-thumb{background:rgba(232,217,176,.22);background-clip:content-box}

.tool-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:5px;margin-bottom:4px}
.tool-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;height:56px;border-radius:8px;color:#C5C3B0;transition:.13s;text-decoration:none;cursor:pointer;background:rgba(232,217,176,.06);border:1px solid rgba(232,217,176,.08)}
.tool-btn span{font-size:10.5px;font-weight:600}
.tool-btn:hover{background:rgba(232,217,176,.12);color:#fff;transform:translateY(-1px)}
.tool-btn svg{opacity:.9}

.navitem{display:flex;align-items:center;gap:11px;height:38px;padding:0 12px;border-radius:8px;color:#C5C3B0;font-size:13.5px;font-weight:400;transition:.13s;cursor:pointer;text-decoration:none;background:none;border:0;width:100%;text-align:left;font-family:inherit}
.navitem svg{flex:0 0 auto;opacity:.92}
.navitem .cap{flex:1 1 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.navitem:hover{background:rgba(232,217,176,.08);color:#fff}
.navitem.active{background:linear-gradient(90deg,var(--it-gold),#D9BC74);color:var(--it-forest-deep);box-shadow:0 8px 18px -10px rgba(201,169,97,.55)}
.navitem.active svg{opacity:1}
.navitem .pill{font-size:10.5px;font-weight:700;background:rgba(232,217,176,.18);color:var(--it-gold-light);border-radius:99px;padding:1px 7px;font-family:var(--ff-num)}
.navitem.active .pill{background:rgba(14,77,44,.18);color:var(--it-forest-deep)}

.side-label{display:flex;align-items:center;gap:8px;font-size:10.5px;font-weight:700;letter-spacing:.9px;text-transform:uppercase;color:#C5C3B0;opacity:.7;margin:16px 8px 7px}
.side-label::after{content:"";flex:1;height:1px;background:rgba(232,217,176,.14)}

.group-head{display:flex;align-items:center;gap:10px;height:40px;padding:0 6px 0 12px;border-radius:8px;color:#fff;font-weight:400;font-size:13.5px;transition:.13s;width:100%;text-align:left;background:none;border:0;cursor:pointer;font-family:inherit}
.group-head:hover{background:rgba(232,217,176,.08)}
.group-head.role-active{background:linear-gradient(90deg,var(--it-gold),#D9BC74);color:var(--it-forest-deep)}
.group-head.role-active .gi{background:rgba(14,77,44,.14)}
.group-head.role-active .cnt{color:var(--it-forest-deep)}
.group-head .gi{width:26px;height:26px;border-radius:7px;background:rgba(232,217,176,.12);display:grid;place-items:center;flex:0 0 auto}
.group-head .cap{flex:1 1 auto}
.group-head .cnt{font-size:11px;font-weight:700;color:#C5C3B0;font-family:var(--ff-num);background:rgba(232,217,176,.14);border-radius:99px;padding:1px 7px}
.group-head.role-active .cnt{background:rgba(14,77,44,.16)}
.group-chev{display:grid;place-items:center;width:26px;height:26px;border-radius:6px;flex:0 0 auto;transition:.13s;color:#C5C3B0}
.group-chev:hover{background:rgba(232,217,176,.16)}
.group-head.role-active .group-chev{color:var(--it-forest-deep)}
.group-chev svg{transition:transform .2s;transform:rotate(90deg)}
.group-head.collapsed .group-chev svg{transform:rotate(0deg)}

.sublist{display:flex;flex-direction:column;gap:1px;margin:2px 0 2px;padding-left:14px;position:relative;overflow:hidden}
.sublist::before{content:"";position:absolute;left:21px;top:2px;bottom:6px;width:1.5px;background:rgba(232,217,176,.14)}
.subitem{display:flex;align-items:center;gap:9px;height:33px;padding:0 10px 0 16px;border-radius:7px;color:#C5C3B0;font-size:12.5px;font-weight:400;transition:.12s;position:relative;cursor:pointer;background:none;border:0;width:100%;text-align:left;font-family:inherit;text-decoration:none}
.subitem svg{flex:0 0 auto;opacity:.7}
.subitem .cap{flex:1 1 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.subitem .cnt{font-size:11px;font-weight:600;color:#C5C3B0;opacity:.85;font-family:var(--ff-num)}
.subitem:hover{background:rgba(232,217,176,.08);color:#fff}
.subitem:hover svg{opacity:1}
.subitem.active{background:rgba(201,169,97,.22);color:#fff}
.subitem.active::before{content:"";position:absolute;left:-1px;top:7px;bottom:7px;width:3px;border-radius:99px;background:var(--it-gold)}
.subitem.active svg{opacity:1;color:var(--it-gold)}
.subitem.active .cnt{color:var(--it-gold-light);opacity:1}

.locked .subitem{color:#C5C3B0;opacity:.55}
.locked .subitem .lk{margin-left:auto;color:#C5C3B0}
.locked .subitem:hover{opacity:1;background:rgba(232,217,176,.06)}

.upsell{margin:12px 6px 2px;padding:14px;border-radius:14px;background:linear-gradient(150deg,rgba(201,169,97,.22),rgba(31,138,63,.16));border:1px solid rgba(232,217,176,.14)}
.upsell h5{margin:0 0 4px;font-size:13px;color:#fff;font-weight:700}
.upsell p{margin:0 0 11px;font-size:11.5px;color:#C5C3B0;line-height:1.5}
.upsell button{width:100%;height:34px;border-radius:8px;background:var(--it-gold);color:var(--it-forest-deep);font-weight:700;font-size:12.5px;transition:.14s;border:0;cursor:pointer;font-family:inherit}
.upsell button:hover{background:var(--it-gold-mid);color:#fff;transform:translateY(-1px)}

/* ---------------- Main content (natural page flow) ---------------- */
.app-main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;padding:16px 18px 18px}

.crumb{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--it-muted);margin-bottom:8px}
.crumb b{color:var(--it-ink-2);font-weight:600}
.crumb .sep{opacity:.5}

.content-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:12px}
.content-head h1{margin:0;font-size:21px;font-weight:600;letter-spacing:-.2px;display:flex;align-items:center;gap:10px;color:var(--it-forest)}
.content-head h1 .ct{font-size:13px;font-weight:600;color:var(--it-forest);background:var(--it-gold-light);padding:3px 10px;border-radius:99px;font-family:var(--ff-num)}
.content-head .sub{font-size:12.5px;color:var(--it-muted);margin-top:3px}

.sortwrap{display:flex;align-items:center;gap:8px}
.sortwrap label{font-size:12px;color:var(--it-muted);font-weight:500}
.app-select{position:relative;display:inline-flex;align-items:center;height:36px;border:1px solid var(--it-line);border-radius:8px;background:#fff;padding:0 34px 0 13px;font-size:12.5px;font-weight:400;color:var(--it-ink);cursor:pointer;font-family:inherit;transition:.14s}
.app-select:hover{border-color:var(--it-gold)}
.app-select svg{position:absolute;right:11px;color:var(--it-muted);pointer-events:none}
.app-select select{position:absolute;inset:0;opacity:0;cursor:pointer;font-family:inherit;width:100%;height:100%;border:0;background:transparent}

/* NOTE: no overflow on .panel - it would break the sticky thead.
   Rounded corners on the bottom (table foot) handle the visual; top corners
   are clipped to the panel border via border-top-left/right-radius on .tabs. */
.panel{background:#fff;border:1px solid var(--it-line);border-radius:14px;box-shadow:0 1px 2px rgba(14,77,44,.04);display:flex;flex-direction:column;margin-bottom:16px}
.panel .tabs{border-top-left-radius:14px;border-top-right-radius:14px}
.panel .tablefoot{border-bottom-left-radius:14px;border-bottom-right-radius:14px}

/* Filter tabs */
.tabs{display:flex;align-items:center;gap:6px;padding:11px 14px;border-bottom:1px solid var(--it-line-soft);flex-wrap:wrap}
.tab{height:32px;padding:0 14px;border-radius:var(--r-pill);font-size:12.5px;font-weight:600;color:var(--it-ink-2);background:var(--it-cream-2);border:1px solid transparent;transition:.13s;display:inline-flex;align-items:center;gap:7px;cursor:pointer;font-family:inherit}
.tab .n{font-size:11px;font-weight:700;background:#fff;color:var(--it-muted);border-radius:99px;padding:0 6px;min-width:18px;text-align:center;border:1px solid var(--it-line);font-family:var(--ff-num)}
.tab:hover{background:var(--it-cream-3);color:var(--it-forest)}
.tab.on{background:var(--it-forest);color:var(--it-gold-light);border-color:var(--it-forest)}
.tab.on .n{background:rgba(232,217,176,.22);color:var(--it-gold-light);border-color:transparent}
.tabs .grow{flex:1 1 auto}
.tabs .ghost{height:32px;padding:0 12px;border-radius:8px;font-size:12px;font-weight:600;color:var(--it-ink-2);border:1px solid var(--it-line);display:inline-flex;align-items:center;gap:7px;background:#fff;transition:.13s;cursor:pointer;font-family:inherit;position:relative}
.tabs .ghost:hover{border-color:var(--it-gold);color:var(--it-forest)}
.tabs .ghost .fbadge{min-width:18px;height:18px;padding:0 5px;border-radius:99px;background:var(--it-gold);color:var(--it-forest-deep);font-size:10.5px;font-weight:700;display:grid;place-items:center;font-family:var(--ff-num)}

/* Table — grows to fit content. No overflow on .tablewrap either
   because overflow on either axis breaks position:sticky for the thead. */
.tablewrap{}
table.data{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}
table.data thead th{position:sticky;top:60px;z-index:20;background:var(--it-cream-2);text-align:left;font-weight:600;font-size:11.5px;letter-spacing:.3px;color:var(--it-muted);padding:10px 14px;border-bottom:1px solid var(--it-line);white-space:nowrap;text-transform:uppercase;box-shadow:0 2px 4px -2px rgba(14,77,44,.12)}
table.data thead th.num{text-align:right}
table.data tbody td{padding:9px 14px;border-bottom:1px solid var(--it-line-soft);vertical-align:middle}
table.data tbody tr{transition:background .1s;cursor:pointer}
table.data tbody tr:hover{background:var(--it-gold-light)}
table.data tbody tr:hover td:first-child{box-shadow:inset 3px 0 0 var(--it-forest)}

.cell-date{color:var(--it-ink-2);font-weight:500;white-space:nowrap;font-variant-numeric:tabular-nums;font-family:var(--ff-num);font-size:13.5px}
.code{font-variant-numeric:tabular-nums;font-weight:600;color:var(--it-ink-2);letter-spacing:.2px;font-family:var(--ff-num)}

.orgname{display:flex;align-items:center;gap:9px;min-width:0}
.orgname .nm{font-weight:400;color:var(--it-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:380px}
.orgname .nm:hover{color:var(--it-forest);text-decoration:underline;text-underline-offset:2px}
.ver{font-size:11px;font-weight:400;color:var(--it-muted);background:var(--it-cream-2);border-radius:5px;padding:1px 8px;white-space:nowrap;font-family:inherit;text-transform:none}
.new{font-size:9.5px;font-weight:800;letter-spacing:.5px;color:var(--it-forest-deep);background:var(--it-gold);border-radius:4px;padding:2px 6px;white-space:nowrap;box-shadow:0 2px 6px -1px rgba(201,169,97,.4)}

.cap-baht{text-align:right;font-variant-numeric:tabular-nums;font-weight:600;color:var(--it-ink);white-space:nowrap;font-family:var(--ff-num)}
.cap-baht.empty{color:var(--it-muted);font-weight:500}
.cap-baht small{color:var(--it-muted);font-weight:500;font-size:11px}

.prov{display:inline-flex;align-items:center;gap:6px;color:var(--it-ink-2);font-weight:500;white-space:nowrap}
.prov svg{color:var(--it-muted)}

.status{display:flex;align-items:center;gap:6px}
.chip{display:inline-flex;align-items:center;gap:5px;height:24px;padding:0 9px;border-radius:99px;font-size:11.5px;font-weight:600;white-space:nowrap}
.chip.win{background:#DCFCE7;color:#15803D;border:1px solid #86EFAC}
.chip.lose{background:#E8E6E0;color:#1A1A1A;border:1px solid #C4C0B0}
.chip.hot{background:#FCE2E8;color:#BE123C;border:1px solid #FBA8B8}
.chip.warm{background:#E7EEFE;color:#1D4ED8;border:1px solid #B6CDFE}
.chip.none{background:var(--it-cream-2);color:var(--it-muted);border:1px dashed var(--it-line)}
.chip.stars{background:#FBF4E2;border:1px solid var(--it-gold-light);padding:0 7px;gap:1px}
.chip.stars svg{display:block}
.chip.blk{background:#E8E6E0;color:#1A1A1A;border:1px solid #C4C0B0}
.metaicons{display:inline-flex;gap:6px;align-items:center;color:var(--it-muted)}
.metaicons .mi{display:inline-flex;align-items:center;gap:2px;font-size:11px;font-weight:600;font-family:var(--ff-num)}

.starbtn{display:grid;place-items:center;width:30px;height:30px;border-radius:8px;color:var(--it-muted);transition:.12s;background:none;border:0;cursor:pointer}
.starbtn:hover{background:var(--it-gold-light);color:var(--it-gold-mid)}
.starbtn.on{color:var(--it-gold-mid)}
.starbtn.on svg{fill:var(--it-gold)}

/* Pagination */
.tablefoot{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 14px;border-top:1px solid var(--it-line);background:var(--it-cream-2)}
.tablefoot .info{font-size:12px;color:var(--it-muted)}
.tablefoot .info b{color:var(--it-ink-2);font-weight:600;font-family:var(--ff-num)}
.pager{display:flex;align-items:center;gap:4px}
.pager button{min-width:32px;height:32px;border-radius:8px;font-size:12.5px;font-weight:600;color:var(--it-ink-2);transition:.12s;padding:0 6px;background:none;border:0;cursor:pointer;font-family:var(--ff-num)}
.pager button:hover{background:#fff;box-shadow:0 1px 2px rgba(14,77,44,.08)}
.pager button.on{background:var(--it-forest);color:var(--it-gold-light)}
.pager button:disabled{opacity:.4;cursor:not-allowed}
.pager .pg-ellip{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:32px;color:var(--it-muted);font-weight:600;font-size:13px;padding:0 2px;user-select:none}

/* Drawer */
.scrim{position:fixed;inset:0;background:rgba(8,46,26,.4);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:.25s;z-index:40}
.scrim.show{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100vh;width:440px;max-width:92vw;background:#fff;box-shadow:0 24px 60px -20px rgba(14,77,44,.4);transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:50;display:flex;flex-direction:column}
.drawer.show{transform:none}
.drawer-head{padding:18px 20px;border-bottom:1px solid var(--it-line);position:relative}
.drawer-head .x{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:var(--it-muted);background:none;border:0;cursor:pointer}
.drawer-head .x:hover{background:var(--it-cream-2);color:var(--it-ink)}
.drawer-head .eyebrow{font-size:11.5px;font-weight:400;color:var(--it-forest);margin-bottom:5px;display:flex;align-items:center;gap:8px}
.drawer-head h2{margin:0;font-size:19px;font-weight:400;line-height:1.3;padding-right:36px;color:var(--it-forest)}
.drawer-head .codeline{margin-top:8px;font-size:12.5px;color:var(--it-muted);font-variant-numeric:tabular-nums;font-family:var(--ff-num)}
.drawer-body{flex:1 1 auto;overflow-y:auto;padding:18px 20px}
.drawer-body .btn{height:42px;border-radius:10px;font-weight:400;font-size:13.5px;display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;width:100%;background:var(--it-gold);color:var(--it-forest-deep);box-shadow:0 12px 26px -10px rgba(201,169,97,.5);transition:.14s}
.drawer-body .btn:hover{background:var(--it-gold-mid);color:#fff}
.kv{display:grid;grid-template-columns:120px 1fr;gap:10px 12px;font-size:13px;margin:18px 0 0}
.kv dt{color:var(--it-muted);font-weight:400}
.kv dd{margin:0;color:var(--it-ink);font-weight:400}
.drawer-sec-t{font-size:11px;font-weight:400;letter-spacing:.7px;text-transform:uppercase;color:var(--it-muted);margin:22px 0 12px;display:flex;align-items:center;gap:8px}
.drawer-sec-t::after{content:"";flex:1;height:1px;background:var(--it-line-soft)}

/* drawer memo timeline */
.dr-tl{display:flex;gap:11px;padding-bottom:14px;position:relative}
.dr-tl:not(:last-child)::before{content:"";position:absolute;left:5px;top:14px;bottom:0;width:2px;background:var(--it-line)}
.dr-tl-dot{width:12px;height:12px;border-radius:50%;background:var(--it-gold);border:2px solid #fff;box-shadow:0 0 0 1px var(--it-gold);flex:0 0 auto;margin-top:3px}
.dr-tl-body{flex:1 1 auto;min-width:0}
.dr-tl-text{font-size:13px;color:var(--it-ink);line-height:1.5}
.dr-tl-meta{font-size:11px;color:var(--it-muted);margin-top:3px;font-family:var(--ff-num)}

@media (max-width:1180px){
  .appbar .brand .tagline{display:none}
  .member .lbl{display:none}
}
@media (max-width:980px){
  .app-search{max-width:none}
  .user .nm{display:none}
}
.contact-hero{position:relative;background:radial-gradient(800px 360px at 85% -20%,rgba(201,169,97,.22),transparent 60%),linear-gradient(160deg,var(--it-forest),var(--it-forest-deep));color:#fff;overflow:hidden}
.contact-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(232,217,176,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(232,217,176,.05) 1px,transparent 1px);background-size:44px 44px;mask-image:radial-gradient(circle at 70% 30%,#000,transparent 75%);opacity:.6}
.contact-hero-in{position:relative;padding:54px 0 60px;text-align:center}
.contact-hero .crumb{display:flex;align-items:center;gap:8px;font-size:13px;color:#C5C3B0;margin-bottom:18px;justify-content:center}
.contact-hero .crumb a:hover{color:var(--it-gold)}
.contact-hero .crumb .sep{opacity:.5}
.contact-hero .ct-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(232,217,176,.1);border:1px solid rgba(232,217,176,.22);padding:6px 14px;border-radius:var(--r-pill);font-size:13px;font-weight:500;color:var(--it-gold-light);margin-bottom:18px}
.contact-hero h1{font-size:40px;line-height:1.2;font-weight:700;letter-spacing:-.6px;margin:0 0 14px;color:#fff;text-wrap:balance}
.contact-hero p{font-size:16.5px;color:#D5D2C0;margin:0 auto;max-width:680px;text-wrap:pretty}

.info-sec{padding:56px 0 28px}
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:880px){.info-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.info-grid{grid-template-columns:1fr}}
.info-box{display:flex;gap:14px;background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg);padding:20px 22px;transition:.16s;box-shadow:0 1px 2px rgba(14,77,44,.04)}
.info-box:hover{border-color:var(--it-gold);box-shadow:0 18px 36px -22px rgba(14,77,44,.2);transform:translateY(-2px)}
.info-box .ii{width:46px;height:46px;border-radius:12px;background:var(--it-gold-light);color:var(--it-forest);display:grid;place-items:center;flex:0 0 auto}
.info-box h5{margin:0 0 4px;font-size:14.5px;font-weight:600;color:var(--it-forest);letter-spacing:.2px}
.info-box p,.info-box a{margin:0;font-size:13.5px;color:var(--it-ink-2);line-height:1.6;word-break:break-word}
.info-box a{color:var(--it-forest);font-weight:600}
.info-box a:hover{text-decoration:underline}

.contact-form-sec{padding:8px 0 64px}
.contact-form-sec .form-card{max-width:860px;margin:0 auto}

/* =================================================================
   COMPANY 360 detail page — firmdetail.asp (body.it-app)
   Reuses .appbar from the app shell. Content in .detail-wrap.
   ================================================================= */
/* --- Detail popup top bar (logo + title + close) --- */
.detailbar{height:60px;flex:0 0 auto;background:#fff;border-bottom:1px solid var(--it-line);display:flex;align-items:center;gap:16px;padding:0 22px;position:sticky;top:0;z-index:30;box-shadow:0 1px 3px rgba(14,77,44,.05)}
.detailbar .brand{display:flex;align-items:center;flex:0 0 auto}
.detailbar .brand img{height:34px;display:block}
.detailbar .vline{width:1px;height:28px;background:var(--it-line);margin:0 16px;flex:0 0 auto}
.detailbar .db-title{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;justify-content:center}
.detailbar .db-title .db-eyebrow{font-size:11px;font-weight:600;color:var(--it-gold-mid);letter-spacing:.4px;display:flex;align-items:center;gap:6px}
.detailbar .db-title .db-name{font-size:15.5px;font-weight:600;color:var(--it-forest);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.detailbar .db-lang{display:flex;border:1px solid var(--it-line);border-radius:var(--r-pill);overflow:hidden;height:32px;background:var(--it-cream-2);flex:0 0 auto}
.detailbar .db-lang a{padding:0 12px;font-size:12px;font-weight:600;color:var(--it-muted);display:flex;align-items:center;text-decoration:none}
.detailbar .db-lang a.on{background:var(--it-forest);color:var(--it-gold-light)}
.detailbar .db-close{display:inline-flex;align-items:center;gap:7px;height:38px;padding:0 16px 0 13px;border-radius:var(--r-pill);background:var(--it-gold);color:var(--it-forest-deep);border:0;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:.14s;flex:0 0 auto}
.detailbar .db-close:hover{background:var(--it-gold-mid);color:#fff}

/* --- Detail popup footer (copyright) --- */
.detail-footer{background:var(--it-cream-2);color:var(--it-muted);padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:12.5px;font-weight:400;border-top:1px solid var(--it-line)}
.detail-footer .df-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.detail-footer .df-left img{height:24px;opacity:.7}
.detail-footer .df-links{display:flex;gap:16px}
.detail-footer .df-links a{color:var(--it-muted);text-decoration:none;font-weight:500;transition:.12s}
.detail-footer .df-links a:hover{color:var(--it-forest);text-decoration:underline}

.detail-wrap{flex:1 1 auto;background:var(--it-cream-2)}
.detail-inner{max-width:1380px;margin:0 auto;padding:14px 24px 40px}

/* back bar + crumbs */
.backbar{display:flex;align-items:center;gap:10px;margin:4px 0 14px;font-size:12.5px;color:var(--it-muted);flex-wrap:wrap}
.backbar a.back{display:inline-flex;align-items:center;gap:6px;color:var(--it-ink-2);font-weight:600;text-decoration:none;height:32px;padding:0 12px 0 9px;border:1px solid var(--it-line);border-radius:var(--r-pill);background:#fff;transition:.13s}
.backbar a.back:hover{border-color:var(--it-gold);background:var(--it-cream-2)}
.backbar .crumbs{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.backbar .crumbs b{color:var(--it-ink-2);font-weight:600}
.backbar .sep{opacity:.5}

/* hero */
.fd-hero{background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg);box-shadow:0 1px 2px rgba(14,77,44,.04);padding:20px 22px;display:flex;gap:20px;align-items:flex-start;margin-bottom:16px}
.fd-hero .h-emblem{width:60px;height:60px;border-radius:14px;flex:0 0 auto;display:grid;place-items:center;color:var(--it-gold-light);background:linear-gradient(150deg,var(--it-forest),var(--it-forest-mid));box-shadow:0 10px 22px -10px rgba(14,77,44,.5)}
.fd-hero .h-main{flex:1 1 auto;min-width:0}
.fd-hero .h-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:7px}
.badge-type{font-size:12px;font-weight:600;color:var(--it-forest);background:var(--it-gold-light);padding:3px 11px;border-radius:99px}
.badge-status{font-size:12px;font-weight:600;color:var(--it-forest);background:var(--it-success-soft);padding:3px 11px;border-radius:99px;display:inline-flex;align-items:center;gap:6px}
.badge-status .d{width:7px;height:7px;border-radius:50%;background:var(--it-forest-mid)}
.fd-hero h1{margin:0;font-size:25px;font-weight:600;letter-spacing:-.3px;line-height:1.25;color:var(--it-forest)}
.fd-hero .h-meta{display:flex;flex-wrap:wrap;gap:6px 18px;margin-top:9px;font-size:13px;color:var(--it-ink-2)}
.fd-hero .h-meta span{display:inline-flex;align-items:center;gap:6px}
.fd-hero .h-meta svg{color:var(--it-muted)}
.fd-hero .h-actions{display:flex;flex-direction:column;align-items:flex-end;gap:10px;flex:0 0 auto}
.linkrow{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.linkbtn{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 13px;border-radius:8px;border:1px solid var(--it-line);background:#fff;font-size:12.5px;font-weight:600;color:var(--it-ink-2);text-decoration:none;transition:.13s}
.linkbtn:hover{border-color:var(--it-gold);background:var(--it-cream-2);transform:translateY(-1px)}
.linkbtn.fb svg{color:#1877F2}
.linkbtn.line svg{color:#06C755}
.linkbtn.web svg{color:var(--it-forest)}
.linkbtn.map svg{color:#EA4335}
.linkbtn.disabled{opacity:.45;pointer-events:none}

/* layout grid */
.detail-grid{display:grid;grid-template-columns:minmax(0,1fr) 372px;gap:16px;align-items:start}
.col-side{position:sticky;top:74px;display:flex;flex-direction:column;gap:16px}
@media(max-width:1080px){.detail-grid{grid-template-columns:1fr}.col-side{position:static}.fd-hero{flex-wrap:wrap}.fd-hero .h-actions{align-items:flex-start;width:100%}.linkrow{justify-content:flex-start}}

/* generic card */
.fd-card{background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg);box-shadow:0 1px 2px rgba(14,77,44,.04);overflow:hidden}
.fd-card-h{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--it-line-soft)}
.fd-card-h .ti{display:flex;align-items:center;gap:9px;font-size:15px;font-weight:600;flex:1 1 auto;color:var(--it-forest)}
.fd-card-h .ti svg{color:var(--it-gold-mid)}
.fd-card-h .ti .n{font-size:12px;font-weight:700;color:var(--it-muted);background:var(--it-cream-2);border-radius:99px;padding:1px 9px;font-family:var(--ff-num)}
.fd-card-h .act{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:8px;font-size:12.5px;font-weight:600;color:var(--it-forest);background:var(--it-gold-light);transition:.13s;border:0;cursor:pointer;font-family:inherit}
.fd-card-h .act:hover{background:var(--it-gold);color:var(--it-forest-deep)}
.fd-card-b{padding:18px}
.cards-stack{display:flex;flex-direction:column;gap:16px}

/* company info grid */
.info-gridx{display:grid;grid-template-columns:130px 1fr;gap:1px;font-size:13.5px;background:var(--it-line-soft);border-radius:var(--r);overflow:hidden;border:1px solid var(--it-line-soft)}
.info-gridx dt{background:var(--it-cream-2);padding:11px 14px;color:var(--it-muted);font-weight:500;margin:0}
.info-gridx dd{background:#fff;padding:11px 14px;margin:0;color:var(--it-ink);font-weight:400;display:flex;align-items:center;gap:8px}
.info-gridx dd.muted{color:var(--it-muted);font-weight:400}
.info-gridx dd a{color:var(--it-forest);text-decoration:none;font-weight:400}
.info-gridx dd a:hover{text-decoration:underline}

/* tabbed panel */
.fd-tabbar{padding:0 8px;border-bottom:1px solid var(--it-line);display:flex;align-items:center;gap:2px;overflow-x:auto}
.tabnav-btn{height:50px;padding:0 16px;font-family:inherit;font-weight:600;font-size:14px;color:var(--it-muted);border-bottom:2.5px solid transparent;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;transition:.13s;background:none;border-top:0;border-left:0;border-right:0;cursor:pointer}
.tabnav-btn svg{opacity:.8}
.tabnav-btn:hover{color:var(--it-forest)}
.tabnav-btn.on{color:var(--it-forest);border-bottom-color:var(--it-gold)}
.tabnav-btn.on svg{opacity:1;color:var(--it-gold-mid)}
.tabnav-btn .n{font-size:11.5px;font-weight:700;background:var(--it-cream-2);color:var(--it-muted);border-radius:99px;padding:1px 8px;min-width:20px;text-align:center;font-family:var(--ff-num)}
.tabnav-btn.on .n{background:var(--it-gold);color:var(--it-forest-deep)}
.fd-tabpane{display:none}
.fd-tabpane.on{display:block}

/* empty state */
.fd-empty{text-align:center;padding:46px 20px;color:var(--it-muted)}
.fd-empty .ic{width:54px;height:54px;border-radius:50%;background:var(--it-cream-2);color:var(--it-gold-mid);display:grid;place-items:center;margin:0 auto 14px}
.fd-empty h4{margin:0 0 4px;font-size:15px;font-weight:600;color:var(--it-ink-2)}
.fd-empty p{margin:0;font-size:13px}

/* CRM card */
.crm .fd-card-b{display:flex;flex-direction:column;gap:16px}
.crm-label{font-size:12px;font-weight:700;color:var(--it-ink-2);margin-bottom:9px;letter-spacing:.2px}
/* CRM interest: 5-star rating + Blacklist (0) */
.imp{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.stars-pick{display:inline-flex;gap:2px}
.star-opt{background:none;border:none;padding:2px;cursor:pointer;color:#E2DDD0;line-height:0;border-radius:6px;font-family:inherit}
.star-opt svg{fill:currentColor;stroke:currentColor;stroke-width:1}
.star-opt.on{color:var(--it-gold)}
.star-opt:focus-visible{outline:2px solid var(--it-gold);outline-offset:1px}
.blk-opt{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:var(--r);border:1.5px solid var(--it-line);background:#fff;color:var(--it-muted);cursor:pointer;font-family:inherit;font-size:12px;font-weight:600}
.blk-opt .lab{line-height:1}
.blk-opt:hover{border-color:#1A1A1A;background:#E8E6E0;color:#1A1A1A}
.blk-opt.on{border-color:#1A1A1A;background:#E8E6E0;color:#1A1A1A}
.imp-hint{font-size:11px;color:var(--it-muted-2);margin-top:7px}

.fd-inp,.fd-ta,.fd-sel{width:100%;height:40px;border:1px solid var(--it-line);border-radius:var(--r);padding:0 12px;font-family:inherit;font-size:13.5px;color:var(--it-ink);background:#fff;outline:none;transition:.14s}
.fd-inp::placeholder,.fd-ta::placeholder{color:var(--it-muted)}
.fd-inp:focus,.fd-ta:focus,.fd-sel:focus{border-color:var(--it-gold);box-shadow:0 0 0 3px var(--it-gold-light)}
.fd-ta{height:auto;min-height:80px;padding:10px 12px;resize:vertical;line-height:1.5}
.fl{font-size:12px;font-weight:600;color:var(--it-ink-2);margin-bottom:6px;display:block}
.btn-block{height:42px;border-radius:var(--r);background:var(--it-gold);color:var(--it-forest-deep);font-weight:700;font-size:13.5px;width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:.14s;border:0;cursor:pointer;font-family:inherit}
.btn-block:hover{background:var(--it-gold-mid);color:#fff}
.btn-block.saved{background:var(--it-forest-mid);color:#fff;box-shadow:0 8px 18px -8px rgba(31,138,63,.5)}
.btn-block.saved svg{animation:none}

/* success toast (bottom-right) */
.fd-toast{position:fixed;right:22px;bottom:22px;z-index:120;display:flex;align-items:center;gap:9px;background:var(--it-forest);color:#fff;font-size:13.5px;font-weight:600;padding:12px 18px;border-radius:12px;box-shadow:0 18px 40px -14px rgba(14,77,44,.55);transform:translateY(20px);opacity:0;pointer-events:none;transition:.25s cubic-bezier(.3,1.2,.5,1)}
.fd-toast.show{transform:translateY(0);opacity:1}
.fd-toast svg{color:var(--it-gold-light);flex:0 0 auto}
.reminder-chip{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--it-gold-mid);background:var(--it-gold-light);border-radius:99px;padding:5px 12px}

/* Contacts card */
.contact-item{display:flex;gap:11px;align-items:center;padding:11px 14px;border-radius:var(--r);cursor:pointer;transition:.12s;border:1px solid transparent}
.contact-item:hover{background:var(--it-cream-2)}
.contact-item.on{background:var(--it-gold-light);border-color:#D9C580}
.contact-item .av{width:38px;height:38px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-weight:700;font-size:14px;color:#fff;font-family:var(--ff-num)}
.contact-item .c-main{flex:1 1 auto;min-width:0}
.contact-item .c-name{font-weight:600;font-size:13.5px;color:var(--it-ink);display:flex;align-items:center;gap:6px}
.contact-item .c-name .nick{font-size:11.5px;font-weight:500;color:var(--it-muted)}
.contact-item .c-pos{font-size:12px;color:var(--it-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.contact-item .c-right{flex:0 0 auto;text-align:right}
.contact-item .c-cnt{font-size:11px;font-weight:700;color:var(--it-forest);background:var(--it-gold-light);border-radius:99px;padding:1px 8px}

/* Contact card actions (call / edit / delete) — always visible, horizontal row */
.contact-item{position:relative;display:flex !important;flex-direction:row !important;align-items:center;padding:10px 12px;gap:12px;border-radius:10px;flex-wrap:nowrap}
.contact-item .av{width:36px;height:36px;font-size:13px;flex:0 0 36px}
.contact-item .c-main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;justify-content:center}
.contact-item .c-name{font-size:13.5px;line-height:1.35;white-space:normal;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.contact-item .c-pos{font-size:11.5px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.contact-item .c-actions{flex:0 0 auto;display:flex !important;flex-direction:row !important;align-items:center;gap:4px;white-space:nowrap}
.contact-item .c-act{width:30px;height:30px;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;background:transparent;color:var(--it-muted);cursor:pointer;text-decoration:none;transition:.13s;padding:0;font-family:inherit;flex:0 0 30px}
.contact-item .c-act:hover{background:#fff;border-color:var(--it-line)}
.contact-item .c-act.c-act-call:hover{background:var(--it-success-soft);color:var(--it-forest);border-color:#C5E3CF}
.contact-item .c-act.c-act-edit:hover{background:var(--it-gold-light);color:var(--it-forest);border-color:var(--it-gold)}
.contact-item .c-act.c-act-del:hover{background:#FCE2E8;color:#BE123C;border-color:#FBA8B8}

/* Contacts list — tight rows, subtle divider */
.contacts-list{display:flex;flex-direction:column;gap:0}
.contacts-list .contact-item + .contact-item{border-top:1px solid var(--it-line-soft)}
.contact-item .c-last{font-size:10.5px;color:var(--it-muted);margin-top:3px}
.contact-foot{padding:12px 14px;border-top:1px solid var(--it-line-soft);font-size:12px;color:var(--it-muted);display:flex;align-items:center;gap:6px}

/* projects table */
.proj-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 18px 11px}
.proj-toolbar .sum{font-size:12.5px;color:var(--it-muted)}
.proj-toolbar .sum b{color:var(--it-ink-2);font-weight:700}
.proj-table-wrap{overflow:auto}
table.proj-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}
table.proj-table thead th{background:var(--it-forest);text-align:left;font-size:11px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;color:var(--it-gold-light);padding:10px 16px;border-bottom:1px solid var(--it-forest-deep);white-space:nowrap}
table.proj-table tbody td{padding:11px 16px;border-bottom:1px solid var(--it-line-soft);vertical-align:middle}
table.proj-table tbody tr:hover{background:var(--it-gold-light)}
/* "v2" chip beside project name — hidden for v1 (original record). */
.proj-ver{display:inline-block;margin-left:8px;padding:1px 7px;border-radius:99px;background:var(--it-cream-2);color:var(--it-forest);font-size:11px;font-weight:400;font-family:var(--ff-num,inherit);letter-spacing:.3px;vertical-align:middle}

/* Specialist medal — firm.mainfirmcate_maxcate matches the active cat */
.proj-medal{display:inline-block;margin-left:6px;color:var(--it-gold-mid);font-size:15px;vertical-align:middle;cursor:help;transition:color .15s}
.proj-medal:hover{color:var(--it-forest)}

/* chat / communication */
.chatfilter{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:12px 18px 0}
.cf-chip{height:30px;padding:0 12px;border-radius:99px;font-size:12px;font-weight:600;color:var(--it-ink-2);background:var(--it-cream-2);border:1px solid var(--it-line);transition:.12s;display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-family:inherit}
.cf-chip:hover{border-color:var(--it-gold)}
.cf-chip.on{background:var(--it-forest);color:var(--it-gold-light);border-color:var(--it-forest)}
.cf-chip .av{width:18px;height:18px;border-radius:50%;display:grid;place-items:center;font-size:9px;font-weight:700;color:#fff;font-family:var(--ff-num)}
.chat-scroll{padding:18px;max-height:520px;overflow-y:auto;display:flex;flex-direction:column;gap:14px;background:#FBFAF6;background-image:radial-gradient(circle at 1px 1px, rgba(14,77,44,.05) 1px, transparent 0);background-size:18px 18px;border-top:1px solid var(--it-line-soft);min-height:160px}
.chat-scroll .chat-empty{margin:auto;text-align:center;color:var(--it-muted);font-size:13px;background:#fff;border:1px solid var(--it-line);border-radius:12px;padding:18px 22px;box-shadow:0 1px 2px rgba(14,77,44,.05)}
.date-sep{display:flex;align-items:center;gap:12px;color:var(--it-muted);font-size:11.5px;font-weight:600}
.date-sep::before,.date-sep::after{content:"";flex:1;height:1px;background:var(--it-line)}
.msg{display:flex;gap:10px;max-width:80%}
.msg .av{width:34px;height:34px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-weight:700;font-size:13px;color:#fff;font-family:var(--ff-num)}
.msg .bubble-wrap{display:flex;flex-direction:column;gap:3px;min-width:0}
.msg .who{font-size:11.5px;font-weight:600;color:var(--it-ink-2);display:flex;align-items:center;gap:7px}
.msg .who .tag{font-size:10px;font-weight:600;padding:1px 7px;border-radius:99px}
.msg .bubble{padding:10px 13px;border-radius:14px;font-size:13.5px;line-height:1.5;color:var(--it-ink);box-shadow:0 1px 2px rgba(14,77,44,.06)}
.msg .when{font-size:10.5px;color:var(--it-muted)}
.msg.in{align-self:flex-start}
.msg.in .bubble{background:#fff;border:1px solid var(--it-line);border-top-left-radius:4px}
.msg.in .who .tag{background:var(--it-cream-3);color:var(--it-ink-2)}
.msg.in .av{background:var(--it-gold-mid)}
.msg.out{align-self:flex-end;flex-direction:row-reverse}
.msg.out .bubble-wrap{align-items:flex-end}
.msg.out .bubble{background:var(--it-success-soft);color:var(--it-ink);border:1px solid #C5E3CF;border-top-right-radius:4px;box-shadow:0 2px 6px -3px rgba(14,77,44,.18)}
.msg.out .who .tag{background:var(--it-gold-light);color:var(--it-gold-mid)}
.msg.out .av{background:linear-gradient(135deg,var(--it-forest),var(--it-forest-mid));color:var(--it-gold-light)}
.msg.note{align-self:center;max-width:90%;display:flex;align-items:center;gap:6px}
/* Delete-memo button — small + muted; turns red on hover so users feel safe. */
.msg .when{display:flex;align-items:center;gap:8px}
.msg-del{background:transparent;border:0;padding:2px 4px;color:var(--it-muted-2);cursor:pointer;opacity:.55;border-radius:6px;transition:opacity .15s,color .15s,background .15s;display:inline-flex;align-items:center;justify-content:center}
.msg-del:hover{opacity:1;color:#BE123C;background:rgba(190,18,66,.08)}
.msg-del svg{display:block}
.msg.out .when{flex-direction:row-reverse}
.note-pill{display:flex;align-items:center;gap:9px;background:var(--it-gold-light);color:#7A5A18;border:1px solid #E0CE92;border-radius:12px;padding:9px 14px;font-size:12.5px;line-height:1.45;flex:1;min-width:0}
.note-pill svg{flex:0 0 auto;color:var(--it-gold-mid)}
.note-pill b{font-weight:700}
.chan-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;padding:1px 7px;border-radius:99px}
.chan-badge.call{background:var(--it-success-soft);color:var(--it-forest)}
.chan-badge.meeting{background:var(--it-gold-light);color:var(--it-gold-mid)}
.chan-badge.email{background:#FBEFEC;color:var(--it-coral)}
.msg.out .chan-badge{background:rgba(232,217,176,.25);color:#fff}

/* composer */
.composer{border-top:1px solid var(--it-line);padding:13px 18px;background:#fff}
.composer .c-controls{display:flex;gap:8px;align-items:center;margin-bottom:9px;flex-wrap:wrap}
.dir-seg{display:inline-flex;background:var(--it-cream-2);border:1px solid var(--it-line);border-radius:99px;padding:3px}
.dir-seg button{height:28px;padding:0 12px;border-radius:99px;font-size:11.5px;font-weight:600;color:var(--it-muted);transition:.13s;display:inline-flex;align-items:center;gap:5px;background:none;border:0;cursor:pointer;font-family:inherit}
.dir-seg button.on.out{background:var(--it-forest);color:var(--it-gold-light)}
.dir-seg button.on.in{background:var(--it-ink);color:#fff}
.dir-seg button.on.note{background:var(--it-gold);color:var(--it-forest-deep)}
.composer .c-input{display:flex;gap:10px;align-items:stretch}
.composer textarea{flex:1 1 auto;min-height:96px;max-height:240px;border:1px solid var(--it-line);border-radius:12px;padding:12px 13px;font-family:inherit;font-size:14px;resize:vertical;outline:none;line-height:1.6;transition:.14s}
.composer textarea:focus{border-color:var(--it-gold);box-shadow:0 0 0 3px var(--it-gold-light)}
.c-actions{display:flex;flex-direction:column;gap:8px;flex:0 0 auto;width:110px}
.voice-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:38px;border-radius:10px;background:var(--it-cream-2);border:1px solid var(--it-line);color:var(--it-forest);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:.13s}
.voice-btn:hover{background:var(--it-gold-light);border-color:var(--it-gold)}
.voice-btn.recording{background:#FCE2E8;border-color:#E11D48;color:#BE123C;animation:voicePulse 1.3s ease-in-out infinite}
@keyframes voicePulse{0%,100%{box-shadow:0 0 0 0 rgba(225,29,72,.25)}50%{box-shadow:0 0 0 6px rgba(225,29,72,0)}}
.voice-btn .vmic{display:grid;place-items:center}
.voice-status{margin-top:8px;font-size:12px;color:var(--it-forest);background:var(--it-gold-light);border-radius:8px;padding:7px 12px;font-weight:500;line-height:1.4}
.send-btn{flex:1 1 auto;min-height:38px;border-radius:10px;background:var(--it-gold);color:var(--it-forest-deep);display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:13.5px;font-weight:700;transition:.14s;border:0;cursor:pointer;font-family:inherit}
.send-btn span{line-height:1}
.send-btn:hover{background:var(--it-gold-mid);color:#fff}
.send-btn:disabled{opacity:.45;cursor:not-allowed}
.send-btn:hover{background:var(--it-gold-mid);color:#fff}
.send-btn:disabled{opacity:.4;cursor:not-allowed}
.chan-seg{display:inline-flex;background:var(--it-cream-2);border:1px solid var(--it-line);border-radius:99px;padding:3px}
.chan-seg button{height:28px;padding:0 11px;border-radius:99px;font-size:11.5px;font-weight:600;color:var(--it-muted);transition:.13s;display:inline-flex;align-items:center;gap:5px;background:none;border:0;cursor:pointer;font-family:inherit}
.chan-seg button.on{background:#fff;color:var(--it-forest);box-shadow:0 1px 2px rgba(14,77,44,.08)}
.chan-seg button.on svg{color:var(--it-gold-mid)}
.chan-lead{font-size:11.5px;color:var(--it-muted);font-weight:600}
.mini-sel{height:28px;border:1px solid var(--it-line);border-radius:99px;background:#fff;padding:0 10px;font-family:inherit;font-size:11.5px;font-weight:600;color:var(--it-ink-2);outline:none}

/* modal */
.modal-scrim{position:fixed;inset:0;background:rgba(8,46,26,.45);backdrop-filter:blur(2px);display:none;place-items:center;z-index:80;padding:20px}
.modal-scrim.show{display:grid}
.modal{background:#fff;border-radius:var(--r-lg);box-shadow:0 24px 60px -20px rgba(14,77,44,.4);width:680px;max-width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}
.modal-h{display:flex;align-items:center;gap:10px;padding:18px 22px;border-bottom:1px solid var(--it-line)}
.modal-h svg{color:var(--it-gold-mid)}
.modal-h h3{margin:0;font-size:17px;font-weight:600;flex:1;color:var(--it-forest)}
.modal-h .x{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:var(--it-muted);background:none;border:0;cursor:pointer}
.modal-h .x:hover{background:var(--it-cream-2);color:var(--it-ink)}
.modal-b{padding:22px;overflow-y:auto}
.modal-note{font-size:12.5px;color:var(--it-muted);margin:0 0 18px}
.form-gridx{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-gridx .full{grid-column:1 / -1}
/* Stacked input (no label) — pull up so it sits flush against the input
   in the row above instead of leaving a label-sized gap. */
.fd-inp-stacked{margin-top:-10px}
.modal-f{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--it-line);background:var(--it-cream-2)}
.btn-cancel{height:42px;padding:0 20px;border-radius:10px;font-weight:700;font-size:13.5px;color:var(--it-ink-2);background:#fff;border:1px solid var(--it-line);cursor:pointer;font-family:inherit}
.btn-cancel:hover{background:var(--it-cream-3)}
.btn-save{height:42px;padding:0 22px;border-radius:10px;font-weight:700;font-size:13.5px;color:var(--it-forest-deep);background:var(--it-gold);display:inline-flex;align-items:center;gap:8px;border:0;cursor:pointer;font-family:inherit}
.btn-save:hover{background:var(--it-gold-mid);color:#fff}
.btn-save:disabled{opacity:.5;cursor:not-allowed}
@media(max-width:640px){.form-gridx{grid-template-columns:1fr}.msg{max-width:92%}}

/* =================================================================
   FAVORITE page — firmfavorite.asp (Forest+Gold)
   KPI bar (4 cards) + sort row + table with CRM importance pill
   ================================================================= */
.fav-kpi{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.kpi-card{background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg);padding:14px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:.14s;text-decoration:none}
.kpi-card:hover{border-color:var(--it-gold);transform:translateY(-1px);box-shadow:0 8px 18px -10px rgba(14,77,44,.18)}
.kpi-card.on{border-width:2px;padding:13px 15px}
.kpi-card .ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex:0 0 auto}
.kpi-card .body{display:flex;flex-direction:column;line-height:1.2}
.kpi-card .n{font-size:22px;font-weight:400;color:var(--it-ink);font-family:var(--ff-num)}
.kpi-card .lbl{font-size:11.5px;color:var(--it-muted);font-weight:400;margin-top:2px}
.kpi-card.high .ic{background:#FBF4E2;color:var(--it-gold-mid)} .kpi-card.high.on{border-color:var(--it-gold)}
.kpi-card.s5 .ic,.kpi-card.s4 .ic,.kpi-card.s3 .ic,.kpi-card.s2 .ic,.kpi-card.s1 .ic{background:#FBF4E2;color:var(--it-gold-mid)}
.kpi-card.s5.on,.kpi-card.s4.on,.kpi-card.s3.on,.kpi-card.s2.on,.kpi-card.s1.on{border-color:var(--it-gold)}
.kpi-card.mid  .ic{background:#E7EEFE;color:#1D4ED8} .kpi-card.mid.on{border-color:#2563EB}
.kpi-card.low  .ic{background:#E8E6E0;color:#1A1A1A} .kpi-card.low.on{border-color:#1A1A1A}
.kpi-card.blk  .ic{background:#E8E6E0;color:#1A1A1A} .kpi-card.blk.on{border-color:#1A1A1A}
.kpi-card.all  .ic{background:var(--it-gold-light);color:var(--it-forest)} .kpi-card.all.on{border-color:var(--it-gold)}
/* legacy KPI accents still used by firmcrmreport activity/overdue cards */
.kpi-card.hot  .ic{background:#FCE2E8;color:#BE123C}
.kpi-card.warm .ic{background:#E7EEFE;color:#1D4ED8}
.kpi-card.win  .ic{background:#DCFCE7;color:#15803D}
@media(max-width:900px){.fav-kpi{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.fav-kpi{grid-template-columns:1fr}}

.fav-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg);padding:12px 16px;margin-bottom:12px;flex-wrap:wrap}
.fav-toolbar .sum{font-size:13px;color:var(--it-muted)}
.fav-toolbar .sum b{color:var(--it-ink-2);font-weight:700}
.fav-toolbar .controls{display:flex;align-items:center;gap:10px}
.fav-toolbar .controls label{font-size:12px;color:var(--it-muted);font-weight:600}
.fav-toolbar select{height:34px;padding:0 32px 0 12px;border:1px solid var(--it-line);border-radius:8px;background:#fff;font-family:inherit;font-size:13px;color:var(--it-ink-2);cursor:pointer}

.fav-table-wrap{background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg);overflow:hidden}
table.fav-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13.5px}
table.fav-table thead th{background:var(--it-forest);color:var(--it-gold-light);text-align:left;font-size:11px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;padding:11px 14px;white-space:nowrap}
table.fav-table tbody td{padding:13px 14px;border-bottom:1px solid var(--it-line-soft);vertical-align:middle}
table.fav-table tbody tr:last-child td{border-bottom:0}
table.fav-table tbody tr:hover{background:var(--it-gold-light)}
.fav-firm-cell .fav-fname{font-weight:600;color:var(--it-ink);font-size:13.5px}
.fav-firm-cell .fav-fname:hover{color:var(--it-forest);cursor:pointer;text-decoration:underline}
.fav-firm-cell .fav-fmeta{font-size:11.5px;color:var(--it-muted);margin-top:3px;display:flex;gap:10px;flex-wrap:wrap}
.fav-firm-cell .fav-fmeta span{display:inline-flex;align-items:center;gap:4px}
.fav-note{color:var(--it-ink-2);font-size:12.5px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-width:300px}
.fav-note.empty{color:var(--it-muted);font-style:italic}
.fav-lastmemo{max-width:320px}
.fav-lastmemo-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.fav-lastmemo-date{font-family:var(--ff-num);font-size:12.5px;font-weight:600;color:var(--it-forest)}
.fav-lastmemo-cnt{font-size:11px;font-weight:600;color:var(--it-gold-mid);background:var(--it-gold-light);border-radius:99px;padding:1px 9px;font-family:var(--ff-num)}
.fav-contact-cnt{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:600;color:var(--it-forest);background:var(--it-success-soft);border:1px solid #C5E3CF;border-radius:99px;padding:3px 11px}
.fav-contact-cnt.none{color:var(--it-muted);background:var(--it-cream-2);border-color:var(--it-line);font-weight:500;font-style:italic}
.fav-date{font-family:var(--ff-num);font-size:12.5px;color:var(--it-ink-2);white-space:nowrap}
.fav-alert{display:inline-flex;align-items:center;gap:5px;font-family:var(--ff-num);font-size:12.5px;padding:3px 9px;border-radius:99px;white-space:nowrap;font-weight:600}
.fav-alert.due{background:#FCE2E8;color:#BE123C}
.fav-alert.soon{background:var(--it-gold-light);color:#7A5A18}
.fav-alert.future{background:var(--it-cream-2);color:var(--it-ink-2)}
.fav-alert.none{background:transparent;color:var(--it-muted);font-style:italic;padding:0}
.fav-row-actions{display:flex;gap:6px;justify-content:flex-end}
.fav-row-actions a, .fav-row-actions button{width:32px;height:32px;border-radius:8px;display:inline-grid;place-items:center;background:var(--it-cream-2);color:var(--it-ink-2);border:1px solid var(--it-line);cursor:pointer;text-decoration:none;transition:.13s}
.fav-row-actions a:hover{background:var(--it-gold-light);color:var(--it-forest);border-color:var(--it-gold)}
.fav-row-actions button.remove:hover{background:#FCE2E8;color:#BE123C;border-color:#FBA8B8}

.fav-empty{padding:60px 20px;text-align:center;color:var(--it-muted)}
.fav-empty .ic{width:68px;height:68px;border-radius:50%;background:var(--it-cream-2);color:var(--it-gold-mid);display:grid;place-items:center;margin:0 auto 16px}
.fav-empty h3{margin:0 0 6px;font-size:17px;font-weight:600;color:var(--it-ink-2)}
.fav-empty p{margin:0 0 16px;font-size:13.5px}
.fav-empty .go{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:10px;background:var(--it-gold);color:var(--it-forest-deep);font-weight:700;font-size:13.5px;text-decoration:none}
.fav-empty .go:hover{background:var(--it-gold-mid);color:#fff}

/* =================================================================
   CALENDAR page — firmcalendar.asp (Alert ปฏิทิน)
   Ports class names from design_handoff_icons/design_files/alert.css
   ================================================================= */
.alert-grid{display:grid;grid-template-columns:minmax(0,420px) minmax(0,1fr);gap:16px;align-items:start}
@media(max-width:1000px){.alert-grid{grid-template-columns:1fr}}

/* ---------- Calendar card (left top) ---------- */
.cal-card{background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 1px 2px rgba(14,77,44,.04)}
.cal-card .card-b{padding:16px}
.cal-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cal-title{font-size:17px;font-weight:700;letter-spacing:-.2px;color:var(--it-forest)}
.cal-title span{color:var(--it-muted);font-weight:600;font-size:14px;margin-left:6px}
.cal-nav{display:flex;gap:6px}
.cal-nav a, .cal-nav button{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:var(--it-ink-2);border:1px solid var(--it-line);background:#fff;transition:.13s;text-decoration:none;font-family:inherit;font-size:14px;font-weight:600;cursor:pointer}
.cal-nav a:hover, .cal-nav button:hover{border-color:var(--it-gold);background:var(--it-cream-2)}
.cal-today-btn{height:34px;padding:0 14px;border-radius:9px;font-size:12.5px;font-weight:600;color:var(--it-forest);background:var(--it-gold-light);transition:.13s;text-decoration:none;border:1px solid transparent;display:inline-flex;align-items:center}
.cal-today-btn:hover{background:var(--it-gold);color:var(--it-forest-deep)}

.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px}
.cal-dow span{text-align:center;font-size:11px;font-weight:700;color:var(--it-muted);padding:4px 0}
.cal-dow span.we{color:#BE123C}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-cell{aspect-ratio:1/1;border-radius:10px;border:1px solid transparent;background:var(--it-cream-2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:.12s;position:relative;padding:2px}
.cal-cell .dnum{font-size:14px;font-weight:600;color:var(--it-ink-2);font-family:var(--ff-num)}
.cal-cell.out{background:transparent;cursor:default}
.cal-cell.out .dnum{color:var(--it-muted);opacity:.45}
.cal-cell:not(.out):hover{border-color:var(--it-gold);background:#fff}
.cal-cell.we .dnum{color:#BE123C}
.cal-cell.today{background:#fff;border-color:var(--it-gold)}
.cal-cell.today .dnum{color:var(--it-forest);font-weight:700}
.cal-cell.has{background:#fff;border-color:var(--it-line)}
.cal-cell.sel{background:var(--it-forest);border-color:var(--it-forest)}
.cal-cell.sel .dnum{color:#fff;font-weight:700}
.cal-cell.in-range{background:var(--it-success-soft);border-color:#C5E3CF}
.cal-cell.in-range .dnum{color:var(--it-forest)}

.cal-dots{display:flex;gap:3px;height:6px;align-items:center}
.cal-dots i{width:6px;height:6px;border-radius:50%}
.a-stars{display:inline-flex;gap:1px;vertical-align:middle;margin-left:5px;line-height:0}
.a-stars svg{display:block}
.cal-dots i.high{background:var(--it-gold)}
.cal-dots i.mid{background:#2563EB}
.cal-dots i.low{background:#1A1A1A}
.cal-dots i.blk{background:#1A1A1A}
.cal-dots i.normal{background:var(--it-muted)}
.cal-cell.sel .cal-dots i{background:#fff !important}
.cal-count{position:absolute;top:3px;right:5px;font-size:9.5px;font-weight:700;color:var(--it-muted);font-family:var(--ff-num)}
.cal-cell.has .cal-count{color:var(--it-forest)}
.cal-cell.sel .cal-count{color:rgba(255,255,255,.85)}

.cal-legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:16px;padding-top:14px;border-top:1px solid var(--it-line-soft);font-size:12px;color:var(--it-muted)}
.cal-legend .lg{display:inline-flex;align-items:center;gap:6px}
.cal-legend .lg i{width:8px;height:8px;border-radius:50%}
.cal-legend .lg i.high{background:var(--it-gold)}
.cal-legend .lg i.mid{background:#2563EB}
.cal-legend .lg i.low{background:#1A1A1A}
.cal-legend .lg i.blk{background:#1A1A1A}

/* ---------- Range picker card (left bottom) ---------- */
.range-card{background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 1px 2px rgba(14,77,44,.04)}

/* mode toggle (ปฏิทินรายวัน | เลือกช่วงวันที่) — header right */
.mode-seg{display:inline-flex;background:#fff;border:1px solid var(--it-line);border-radius:var(--r-pill);padding:3px;flex:0 0 auto}
.mode-seg a{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 16px;border-radius:var(--r-pill);font-size:13px;font-weight:600;color:var(--it-muted);transition:.14s;text-decoration:none}
.mode-seg a:hover{color:var(--it-forest)}
.mode-seg a.on{background:var(--it-forest);color:var(--it-gold-light);box-shadow:0 4px 10px -4px rgba(14,77,44,.35)}
.mode-seg a svg{flex:0 0 auto}
.range-card .card-h{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--it-line-soft);font-size:14px;font-weight:600;color:var(--it-forest)}
.range-card .card-h svg{color:var(--it-gold-mid)}
.range-card .card-b{padding:16px;display:flex;flex-direction:column;gap:14px}
.range-fields{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}
.range-fields .rf{flex:1 1 140px;display:flex;flex-direction:column;gap:4px}
.range-fields .rf label{font-size:12px;font-weight:600;color:var(--it-ink-2)}
.range-fields .rf input{height:36px;padding:0 12px;border:1px solid var(--it-line);border-radius:8px;font-family:inherit;font-size:13px;color:var(--it-ink);background:#fff;outline:none;transition:.13s}
.range-fields .rf input:focus{border-color:var(--it-gold);box-shadow:0 0 0 3px var(--it-gold-light)}
.range-fields .dash{padding-bottom:9px;color:var(--it-muted)}
.range-apply{height:36px;padding:0 16px;border-radius:8px;background:var(--it-gold);color:var(--it-forest-deep);font-weight:700;font-size:13px;border:0;cursor:pointer;font-family:inherit;transition:.13s;align-self:flex-end}
.range-apply:hover{background:var(--it-gold-mid);color:#fff}
.range-presets{display:flex;flex-wrap:wrap;gap:7px}
.range-presets .ps-lbl{font-size:12px;font-weight:600;color:var(--it-ink-2);width:100%;margin-bottom:2px}
.preset{height:32px;padding:0 13px;border-radius:99px;font-size:12.5px;font-weight:600;color:var(--it-ink-2);background:var(--it-cream-2);border:1px solid var(--it-line);transition:.12s;font-family:inherit;cursor:pointer}
.preset:hover{border-color:var(--it-gold);background:#fff}
.preset.on{background:var(--it-forest);color:#fff;border-color:var(--it-forest)}
.range-info{font-size:12.5px;color:var(--it-muted);display:flex;align-items:center;gap:7px;padding-top:4px;border-top:1px dashed var(--it-line)}
.range-info b{color:var(--it-forest);font-family:var(--ff-num);font-weight:700}
.range-info .clr{margin-left:auto;display:inline-flex;align-items:center;height:28px;padding:0 12px;border-radius:99px;background:#FCE2E8;color:#BE123C;font-size:11.5px;font-weight:600;border:1px solid #FBA8B8;text-decoration:none;cursor:pointer}
.range-info .clr:hover{background:#BE123C;color:#fff;border-color:#BE123C}

/* KPI cards for calendar (4 buckets) */
.cal-kpi{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
@media(max-width:900px){.cal-kpi{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.cal-kpi{grid-template-columns:1fr}}
.cal-kpi .kpi-card.due  .ic{background:#FCE2E8;color:#BE123C} .cal-kpi .kpi-card.due.on{border-color:#E11D48}
.cal-kpi .kpi-card.today .ic{background:var(--it-gold-light);color:var(--it-forest)} .cal-kpi .kpi-card.today.on{border-color:var(--it-gold)}
.cal-kpi .kpi-card.week .ic{background:#E7EEFE;color:#1D4ED8} .cal-kpi .kpi-card.week.on{border-color:#2563EB}
.cal-kpi .kpi-card.future .ic{background:var(--it-success-soft);color:var(--it-forest)} .cal-kpi .kpi-card.future.on{border-color:var(--it-forest-mid)}

/* alert list (right) */
.alert-list{display:flex;flex-direction:column;gap:10px}
.alert-group-head{display:flex;align-items:center;gap:10px;margin:8px 0 4px}
.alert-group-head h3{margin:0;font-size:14px;font-weight:600;color:var(--it-forest);flex:0 0 auto}
.alert-group-head .line{flex:1 1 auto;height:1px;background:var(--it-line)}
.alert-group-head .cnt{font-size:11.5px;font-weight:700;color:var(--it-muted);background:var(--it-cream-2);border-radius:99px;padding:1px 9px;font-family:var(--ff-num)}
.alert-card{background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg);padding:14px 16px;display:flex;align-items:center;gap:14px;transition:.13s;text-decoration:none;color:inherit;cursor:pointer}
.alert-card:hover{border-color:var(--it-gold);transform:translateY(-1px);box-shadow:0 8px 18px -10px rgba(14,77,44,.18)}
.alert-card.due{border-left:4px solid #E11D48}
.alert-card.today{border-left:4px solid var(--it-gold)}
.alert-card.soon{border-left:4px solid #2563EB}
.alert-card.future{border-left:4px solid var(--it-forest-mid)}
.alert-date-box{flex:0 0 auto;width:60px;text-align:center;border-radius:10px;padding:8px 4px;background:var(--it-cream-2);border:1px solid var(--it-line);font-family:var(--ff-num)}
.alert-date-box .d{font-size:22px;font-weight:700;line-height:1;color:var(--it-ink)}
.alert-date-box .m{font-size:10.5px;font-weight:600;color:var(--it-muted);margin-top:3px;text-transform:uppercase}
.alert-card.due .alert-date-box{background:#FCE2E8;border-color:#FBA8B8} .alert-card.due .alert-date-box .d{color:#BE123C}
.alert-card.today .alert-date-box{background:var(--it-gold-light);border-color:var(--it-gold)} .alert-card.today .alert-date-box .d{color:var(--it-forest)}
.alert-card.soon .alert-date-box{background:#E7EEFE;border-color:#B6CDFE} .alert-card.soon .alert-date-box .d{color:#1D4ED8}
.alert-body{flex:1 1 auto;min-width:0}
.alert-body .a-firm{font-weight:600;font-size:14.5px;color:var(--it-ink);line-height:1.3}
.alert-body .a-meta{font-size:12px;color:var(--it-muted);margin-top:4px;display:flex;flex-wrap:wrap;gap:8px 14px}
.alert-body .a-meta span{display:inline-flex;align-items:center;gap:4px}
.alert-body .a-note{font-size:12.5px;color:var(--it-ink-2);margin-top:6px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.alert-due-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:2px 9px;border-radius:99px}
.alert-due-chip.due{background:#FCE2E8;color:#BE123C}
.alert-due-chip.today{background:var(--it-gold-light);color:var(--it-forest)}
.alert-due-chip.soon{background:#E7EEFE;color:#1D4ED8}
.alert-due-chip.future{background:var(--it-success-soft);color:var(--it-forest)}
.alert-actions{display:flex;flex-direction:column;gap:5px;flex:0 0 auto}
.alert-actions button, .alert-actions a{font-size:11.5px;font-weight:600;padding:5px 12px;border-radius:8px;border:1px solid var(--it-line);background:#fff;color:var(--it-ink-2);cursor:pointer;font-family:inherit;text-decoration:none;text-align:center;transition:.12s;white-space:nowrap}
.alert-actions a.open:hover{background:var(--it-gold-light);border-color:var(--it-gold);color:var(--it-forest)}
.alert-actions button.done:hover{background:var(--it-success-soft);border-color:var(--it-forest-mid);color:var(--it-forest)}

.cal-empty{padding:60px 20px;text-align:center;color:var(--it-muted);background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg)}
.cal-empty .ic{width:68px;height:68px;border-radius:50%;background:var(--it-cream-2);color:var(--it-gold-mid);display:grid;place-items:center;margin:0 auto 16px}
.cal-empty h3{margin:0 0 6px;font-size:17px;font-weight:600;color:var(--it-ink-2)}
.cal-empty p{margin:0;font-size:13.5px}

/* =================================================================
   USAGE HISTORY page — firmusagehistory.asp
   ================================================================= */
.usage-card{background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg);box-shadow:0 1px 2px rgba(14,77,44,.04);overflow:hidden;margin-bottom:16px}
.usage-card .card-h{display:flex;align-items:center;gap:11px;padding:15px 20px;border-bottom:1px solid var(--it-line-soft);background:var(--it-cream-2);flex-wrap:wrap;row-gap:10px}
.usage-card .card-h .ti{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:600;color:var(--it-forest);flex:1}
.usage-card .card-h .ti svg{color:var(--it-gold-mid)}
.chart-toolbar{display:flex;align-items:center;gap:8px}
.chart-seg{display:inline-flex;background:#fff;border:1px solid var(--it-line);border-radius:var(--r-pill);padding:3px}
.chart-seg button{height:30px;padding:0 13px;border-radius:var(--r-pill);font-size:12px;font-weight:600;color:var(--it-muted);transition:.13s;display:inline-flex;align-items:center;gap:6px;border:0;background:none;cursor:pointer;font-family:inherit}
.chart-seg button.on{background:var(--it-forest);color:var(--it-gold-light);box-shadow:0 4px 10px -4px rgba(14,77,44,.3)}
.chart-box{padding:8px 10px 14px}
#usageChart{width:100%;height:380px}

/* login table */
.ip-mono{font-family:"SF Mono",ui-monospace,Menlo,monospace;font-size:12.5px;font-weight:600;color:var(--it-ink-2);background:var(--it-cream-2);border:1px solid var(--it-line-soft);border-radius:6px;padding:2px 8px;display:inline-block}
.time-strong{font-family:var(--ff-num);font-weight:600;color:var(--it-ink)}
.date-strong{font-family:var(--ff-num);color:var(--it-ink-2);font-weight:500;white-space:nowrap}
.usage-table{background:#fff;border:1px solid var(--it-line);border-radius:0 0 var(--r-lg) var(--r-lg);overflow:hidden;border-top:0}
.usage-table table{width:100%;border-collapse:separate;border-spacing:0;font-size:13.5px}
.usage-table thead th{position:static;top:auto;box-shadow:none;background:var(--it-forest);color:var(--it-gold-light);text-align:left;font-size:11px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;padding:11px 14px;white-space:nowrap}
.usage-table tbody td{padding:11px 14px;border-bottom:1px solid var(--it-line-soft);vertical-align:middle}
.usage-table tbody tr:last-child td{border-bottom:0}
.usage-table tbody tr:hover{background:var(--it-gold-light)}
.usage-table .td-center{text-align:center;color:var(--it-muted);font-weight:600;font-family:var(--ff-num)}

/* =================================================================
   REPORT page — firmcrmreport.asp (CRM dashboard)
   ================================================================= */
.rep-grid{display:grid;grid-template-columns:minmax(0,1fr) 372px;gap:16px;align-items:start}
@media(max-width:1080px){.rep-grid{grid-template-columns:1fr}}
.rep-col{display:flex;flex-direction:column;gap:16px}

.period-seg{display:inline-flex;background:#fff;border:1px solid var(--it-line);border-radius:var(--r-pill);padding:3px;flex:0 0 auto}
.period-seg a{height:34px;padding:0 16px;border-radius:var(--r-pill);font-size:12.5px;font-weight:400;color:var(--it-muted);transition:.14s;display:inline-flex;align-items:center;text-decoration:none}
.period-seg a:hover{color:var(--it-forest)}
.period-seg a.on{background:var(--it-forest);color:var(--it-gold-light);box-shadow:0 4px 10px -4px rgba(14,77,44,.3)}

/* Sales Funnel */
.funnel{display:flex;flex-direction:column;gap:10px;padding:4px 2px}
.fn-stage{display:flex;align-items:center;gap:14px}
.fn-bar-wrap{flex:1 1 auto;min-width:0}
.fn-top{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:5px}
.fn-label{font-size:13px;font-weight:400;color:var(--it-ink-2);display:flex;align-items:center;gap:8px}
.fn-label .dot{width:9px;height:9px;border-radius:3px;flex:0 0 auto}
.fn-val{font-size:13.5px;font-weight:400;color:var(--it-ink);font-family:var(--ff-num)}
.fn-val small{color:var(--it-muted);font-weight:500;font-size:11.5px;margin-left:5px}
.fn-track{height:30px;border-radius:8px;background:var(--it-cream-2);overflow:hidden;position:relative}
.fn-fill{height:100%;border-radius:8px;display:flex;align-items:center;transition:width .6s cubic-bezier(.4,0,.2,1)}
.fn-drop{display:flex;align-items:center;gap:5px;justify-content:center;font-size:10.5px;color:var(--it-muted);height:14px}

/* Charts */
.chart-mini{padding:6px 8px 12px}
#donutChart{width:100%;height:260px}
#activityChart{width:100%;height:320px}
.donut-legend{display:flex;flex-direction:column;gap:9px;padding:4px 18px 16px}
.dl-row{display:flex;align-items:center;gap:10px;font-size:13px}
.dl-row .sw{width:11px;height:11px;border-radius:3px;flex:0 0 auto}
.dl-row .nm{color:var(--it-ink-2);font-weight:500;flex:1 1 auto}
.dl-row .vl{font-weight:400;color:var(--it-ink);font-family:var(--ff-num)}
.dl-row .pc{color:var(--it-muted);font-size:11.5px;font-weight:400;width:46px;text-align:right;font-family:var(--ff-num)}

/* Distribution bars */
.dist-list{display:flex;flex-direction:column;gap:12px;padding:4px 2px}
.dist-row{display:grid;grid-template-columns:140px 1fr 52px;align-items:center;gap:12px}
.dist-name{font-size:12.5px;font-weight:400;color:var(--it-ink-2);display:flex;align-items:center;gap:7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dist-name svg{color:var(--it-muted);flex:0 0 auto}
.dist-track{height:22px;border-radius:6px;background:var(--it-cream-2);overflow:hidden}
.dist-fill{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--it-forest),var(--it-gold));transition:width .5s}
.dist-val{font-size:12.5px;font-weight:400;color:var(--it-ink);text-align:right;font-family:var(--ff-num)}
.two-card{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:760px){.two-card{grid-template-columns:1fr}}

/* Action list */
.act-list{display:flex;flex-direction:column}
.act-item{display:flex;gap:12px;padding:13px 16px;border-bottom:1px solid var(--it-line-soft);transition:.12s;cursor:pointer;text-decoration:none;color:inherit}
.act-item:hover{background:var(--it-gold-light)}
.act-item:last-child{border-bottom:0}
.act-when{flex:0 0 auto;width:64px;text-align:center}
.act-when .tag{font-size:10.5px;font-weight:400;border-radius:99px;padding:2px 0;display:block}
.act-when .tag.over{background:#FCE2E8;color:#BE123C}
.act-when .tag.today{background:var(--it-gold);color:var(--it-forest-deep)}
.act-when .tag.soon{background:#E7EEFE;color:#1D4ED8}
.act-when .d{font-size:10.5px;color:var(--it-muted);margin-top:4px;font-family:var(--ff-num)}
.act-line{width:3px;border-radius:99px;flex:0 0 auto;background:var(--it-line)}
.act-line.high{background:var(--it-gold)}
.act-line.mid{background:#2563EB}
.act-line.low{background:#1A1A1A}
.act-line.blk{background:#1A1A1A}
.act-line.normal{background:var(--it-muted)}
.act-main{flex:1 1 auto;min-width:0}
.act-name{font-size:13px;font-weight:400;color:var(--it-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.act-note{font-size:11.5px;color:var(--it-muted);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.act-foot{padding:11px 16px;text-align:center;border-top:1px solid var(--it-line-soft)}
.act-foot a{font-size:12.5px;font-weight:400;color:var(--it-forest);text-decoration:none}
.act-foot a:hover{text-decoration:underline}
.act-empty{padding:32px 16px;text-align:center;color:var(--it-muted);font-size:13px}

.insight{display:flex;gap:10px;align-items:flex-start;padding:13px 15px;background:var(--it-gold-light);border:1px solid #E0CE92;border-radius:var(--r);margin-top:10px}
.insight svg{color:var(--it-gold-mid);flex:0 0 auto;margin-top:1px}
.insight p{margin:0;font-size:12.5px;color:var(--it-ink-2);line-height:1.5}
.insight b{color:var(--it-forest);font-weight:400}

/* generic card used in report */
.rp-card{background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg);box-shadow:0 1px 2px rgba(14,77,44,.04);overflow:hidden}
.rp-card .card-h{display:flex;align-items:center;gap:11px;padding:14px 18px;border-bottom:1px solid var(--it-line-soft)}
.rp-card .card-h .ti{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:600;color:var(--it-forest);flex:1}
.rp-card .card-h .ti svg{color:var(--it-gold-mid)}
.rp-card .card-b{padding:16px 18px}

/* =================================================================
   SEARCH page — firmsearch.asp + firmcontactsearch.asp
   Ports class names from design (search.css/contact.css) → Forest+Gold
   ================================================================= */
.search-panel{background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg);box-shadow:0 1px 2px rgba(14,77,44,.04);margin-bottom:16px;overflow:hidden}
.sp-head{display:flex;align-items:center;gap:11px;padding:15px 20px;border-bottom:1px solid var(--it-line-soft);background:var(--it-cream-2)}
.sp-head .ti{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:700;flex:1;color:var(--it-forest)}
.sp-head .ti svg{color:var(--it-gold-mid)}
.sp-head .collapse{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 13px;border-radius:8px;font-size:12.5px;font-weight:600;color:var(--it-ink-2);border:1px solid var(--it-line);background:#fff;transition:.13s;cursor:pointer;font-family:inherit}
.sp-head .collapse:hover{border-color:var(--it-gold);background:var(--it-cream-2)}
.sp-head .collapse svg{transition:transform .2s}
.sp-head .collapse.closed svg{transform:rotate(-90deg)}

.sp-body{padding:20px}
.sp-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 28px}
.sp-field{display:grid;grid-template-columns:130px 1fr;align-items:center;gap:12px}
.sp-field > label{font-size:13px;color:var(--it-ink-2);font-weight:500;text-align:left}
.sp-field .ctrl{min-width:0}
.sp-field.full{grid-column:1 / -1;grid-template-columns:130px 1fr}
.sp-two{display:flex;gap:8px}
.sp-two .s-inp{min-width:0}

.s-inp,.s-sel{width:100%;height:38px;border:1px solid var(--it-line);border-radius:var(--r);padding:0 12px;font-family:inherit;font-size:13.5px;color:var(--it-ink);background:#fff;outline:none;transition:.14s}
.s-inp::placeholder{color:var(--it-muted)}
.s-inp:focus,.s-sel:focus{border-color:var(--it-gold);box-shadow:0 0 0 3px var(--it-gold-light)}
.s-selwrap{position:relative}
.s-selwrap::after{content:"";position:absolute;right:14px;top:50%;transform:translateY(-25%);border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid var(--it-muted);pointer-events:none}
.s-sel{appearance:none;-webkit-appearance:none;padding-right:32px;font-weight:400;cursor:pointer}

.sp-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 20px;border-top:1px solid var(--it-line-soft);background:var(--it-cream-2);flex-wrap:wrap}
.sp-foot .hint{font-size:12px;color:var(--it-muted);display:flex;align-items:center;gap:7px}
.sp-foot .btns{display:flex;gap:10px}
.btn-search{height:40px;padding:0 22px;border-radius:9px;font-weight:700;font-size:13.5px;color:var(--it-forest-deep);background:var(--it-gold);display:inline-flex;align-items:center;gap:8px;transition:.14s;border:0;cursor:pointer;font-family:inherit}
.btn-search:hover{background:var(--it-gold-mid);color:#fff}
.btn-clear{height:40px;padding:0 18px;border-radius:9px;font-weight:600;font-size:13.5px;color:var(--it-ink-2);background:#fff;border:1px solid var(--it-line);display:inline-flex;align-items:center;gap:7px;transition:.14s;cursor:pointer;font-family:inherit;text-decoration:none}
.btn-clear:hover{background:var(--it-cream-3);border-color:var(--it-gold)}

/* active filter chips */
.active-filters{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px}
.active-filters .af-label{font-size:12.5px;color:var(--it-muted);font-weight:400}
.af-chip{display:inline-flex;align-items:center;gap:7px;height:30px;padding:0 6px 0 12px;border-radius:99px;font-size:12.5px;font-weight:600;color:var(--it-forest);background:var(--it-gold-light);border:1px solid #E0CE92}
.af-chip b{font-weight:700}
.af-chip .x{width:20px;height:20px;border-radius:50%;display:grid;place-items:center;color:var(--it-forest);transition:.12s;text-decoration:none;background:none;border:0;cursor:pointer;font-family:inherit;font-size:15px;line-height:1;padding:0}
.af-chip .x:hover{background:var(--it-gold);color:var(--it-forest-deep)}
.af-clear-all{font-size:12.5px;font-weight:600;color:var(--it-muted);text-decoration:underline;text-underline-offset:2px;cursor:pointer}
.af-clear-all:hover{color:#BE123C}

/* Results summary bar */
.results-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 16px;background:#fff;border:1px solid var(--it-line);border-radius:var(--r-lg) var(--r-lg) 0 0;border-bottom:0}
.results-bar .rc{font-size:13px;color:var(--it-ink-2)}
.results-bar .rc b{color:var(--it-ink);font-weight:700}
.results-bar .rc .q{color:var(--it-forest);font-weight:700}
.results-bar .sort-ctrl{display:flex;align-items:center;gap:8px}
.results-bar .sort-ctrl label{font-size:12px;color:var(--it-muted);font-weight:600}
.results-bar .sort-ctrl select{height:32px;padding:0 28px 0 12px;border:1px solid var(--it-line);border-radius:8px;font-family:inherit;font-size:12.5px;color:var(--it-ink-2);background:#fff;cursor:pointer}

/* Results table wrapper */
.search-results{background:#fff;border:1px solid var(--it-line);border-radius:0 0 var(--r-lg) var(--r-lg);overflow:hidden}
.search-results table.data{width:100%;border-collapse:separate;border-spacing:0;font-size:13.5px}
.search-results table.data thead th{position:static;top:auto;box-shadow:none;background:var(--it-forest);color:var(--it-gold-light);text-align:left;font-size:11px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;padding:11px 14px;white-space:nowrap;vertical-align:bottom}
.search-results table.data tbody td{padding:13px 14px;border-bottom:1px solid var(--it-line-soft);vertical-align:top}
.search-results table.data tbody tr:last-child td{border-bottom:0}
.search-results table.data tbody tr:hover{background:var(--it-gold-light)}

/* Contact roster cell (within search results) */
.contacts-cell{display:flex;flex-direction:column;gap:7px;min-width:0;padding:2px 0}
.cc-none{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--it-muted);font-weight:500}
.cc-roster{display:flex;flex-direction:column;gap:5px}
.cc-row{display:flex;align-items:center;gap:9px;min-width:0}
.cc-av{width:26px;height:26px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-weight:700;font-size:11px;color:#fff}
.cc-info{display:flex;align-items:baseline;gap:7px;min-width:0;flex:1 1 auto}
.cc-name{font-size:13px;font-weight:600;color:var(--it-ink);white-space:nowrap}
.cc-pos{font-size:11.5px;color:var(--it-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.cc-meta{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.cc-memo{font-size:11px;font-weight:700;color:var(--it-forest);background:var(--it-gold-light);border-radius:99px;padding:1px 8px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.cc-memo.zero{color:var(--it-muted);background:var(--it-cream-2)}
.cc-more{display:inline-flex;align-items:center;gap:7px;align-self:flex-start;margin-top:4px;font-size:12px;font-weight:600;color:var(--it-forest);background:none;padding:2px 0;transition:.12s;border:0;cursor:pointer;font-family:inherit;text-decoration:none}
.cc-more:hover{text-decoration:underline}
.cc-summary{display:flex;align-items:center;gap:14px;margin-top:6px;font-size:11.5px;color:var(--it-muted);flex-wrap:wrap;padding-top:6px;border-top:1px dashed var(--it-line)}
.cc-summary > span{display:inline-flex;align-items:center;gap:5px;font-weight:600}
.cc-sum-last.fresh{color:var(--it-forest)}
.cc-sum-last.mid{color:var(--it-gold-mid)}
.cc-sum-last.stale{color:var(--it-muted)}
.cc-sum-memo{color:var(--it-forest)}
.cc-sum-memo.zero{color:var(--it-muted)}

/* segmented control (ค้นหาบริษัท | ค้นหาผู้ติดต่อ) */
.fs-seg{display:inline-flex;background:#fff;border:1px solid var(--it-line);border-radius:var(--r-pill);padding:3px;flex:0 0 auto}
.fs-seg a{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 14px;border-radius:var(--r-pill);font-size:12.5px;font-weight:600;color:var(--it-muted);transition:.13s;text-decoration:none}
.fs-seg a:hover{color:var(--it-forest)}
.fs-seg a.on{background:var(--it-forest);color:var(--it-gold-light);box-shadow:0 4px 10px -4px rgba(14,77,44,.3)}

/* Star badge (importance) — circle badge ในคอลัมน์ดาว */
.star-badge{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:9px;border:1px solid var(--it-line);background:var(--it-cream-2);color:var(--it-muted)}
.star-badge.hot{background:#FCE2E8;border-color:#FBA8B8;color:#BE123C}
.star-badge.warm{background:#E7EEFE;border-color:#B6CDFE;color:#1D4ED8}
.star-badge.win{background:var(--it-success-soft);border-color:#C5E3CF;color:var(--it-forest)}
.star-badge.lose{background:#E8E6E0;border-color:#C4C0B0;color:#1A1A1A}
.star-badge.none{background:transparent;border-color:transparent;color:var(--it-muted)}

/* =================================================================
   CONTACT SEARCH page — firmcontactsearch.asp
   ================================================================= */
.people-list{display:flex;flex-direction:column;background:#fff;border:1px solid var(--it-line);border-radius:0 0 var(--r-lg) var(--r-lg);overflow:hidden}
.person{display:flex;align-items:center;gap:15px;padding:14px 18px;border-bottom:1px solid var(--it-line-soft);transition:.12s}
.person:hover{background:var(--it-gold-light)}
.person:last-child{border-bottom:0}
.person .p-av{width:46px;height:46px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-weight:700;font-size:17px;color:#fff;position:relative}
.person .p-av .pstate{position:absolute;bottom:-1px;right:-1px;width:14px;height:14px;border-radius:50%;border:2.5px solid #fff}
.person .p-av .pstate.on{background:var(--it-forest-mid)}
.person .p-av .pstate.off{background:var(--it-muted)}
.person .p-id{flex:1 1 320px;min-width:0}
.person .p-name{font-size:15px;font-weight:400;color:var(--it-ink);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.person .p-name .nick{font-size:12.5px;font-weight:600;color:var(--it-forest);background:var(--it-gold-light);border-radius:99px;padding:1px 9px}
.person .p-name .left-tag{font-size:11px;font-weight:600;color:var(--it-muted);background:var(--it-cream-2);border-radius:99px;padding:1px 8px}
.person .p-name-link{background:none;border:0;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer;border-bottom:1px dashed transparent;transition:color .15s,border-color .15s}
.person .p-name-link:hover{color:var(--it-forest);border-bottom-color:var(--it-gold)}
.person .p-name-link:focus{outline:0;color:var(--it-forest);border-bottom-color:var(--it-gold)}
.person .p-pos{font-size:12.5px;color:var(--it-ink-2);margin-top:3px}
.person .p-company{font-size:12.5px;color:var(--it-muted);margin-top:4px;display:inline-flex;align-items:center;gap:6px}
.person .p-company a{color:var(--it-forest);font-weight:600;text-decoration:none}
.person .p-company a:hover{text-decoration:underline}
.person .p-contact{flex:0 0 auto;display:flex;flex-direction:column;gap:6px;min-width:188px}
.contact-pill{display:inline-flex;align-items:center;gap:9px;height:36px;padding:0 14px;border-radius:var(--r-pill);font-size:13px;font-weight:600;text-decoration:none;transition:.13s;border:1px solid var(--it-line);background:#fff;color:var(--it-ink)}
.contact-pill.call{color:var(--it-forest);border-color:#C5E3CF;background:var(--it-success-soft)}
.contact-pill.call:hover{background:#C5E3CF}
.contact-pill.mail:hover{border-color:var(--it-gold);background:var(--it-cream-2)}
.contact-pill .num{font-family:var(--ff-num);letter-spacing:.2px}

/* Inline contact list (firmcontactsearch person card) — no pill wrapping.
   Stacks each phone/email on its own line so multi-value contacts read clean. */
.p-contact{display:flex;flex-direction:column;gap:4px;font-size:13px}
.c-link{display:inline-flex;align-items:center;gap:6px;color:var(--it-forest);text-decoration:none;font-weight:500}
.c-link svg{flex-shrink:0;color:var(--it-gold-mid)}
.c-link .num{font-family:var(--ff-num,inherit);letter-spacing:.2px}
.c-link:hover{color:var(--it-forest-deep);text-decoration:underline}
.c-link.muted{color:var(--it-muted-2);font-weight:400;cursor:default}
.c-link.muted:hover{text-decoration:none}
.c-link.mail{color:var(--it-ink-2)}
.c-link.mail:hover{color:var(--it-forest)}
.person .p-last{flex:0 0 auto;width:150px;text-align:left;border-left:1px solid var(--it-line-soft);padding-left:16px}
.person .p-last .ll{font-size:11px;color:var(--it-muted);font-weight:600;margin-bottom:3px}
.person .p-last .lv{font-size:13px;font-weight:700;display:inline-flex;align-items:center;gap:5px;font-family:var(--ff-num)}
.person .p-last .lv.fresh{color:var(--it-forest)}
.person .p-last .lv.mid{color:var(--it-gold-mid)}
.person .p-last .lv.stale{color:var(--it-muted)}
.person .p-last .lv.never{color:var(--it-muted);font-weight:600;font-style:italic}
.person .p-last .memo-line{font-size:11.5px;color:var(--it-forest);font-weight:600;margin-top:6px;display:inline-flex;align-items:center;gap:5px}
.person .p-act{flex:0 0 auto}
.hist-btn{display:inline-flex;align-items:center;gap:7px;height:38px;padding:0 14px;border-radius:var(--r);font-size:12.5px;font-weight:600;color:var(--it-forest);background:var(--it-gold-light);transition:.13s;white-space:nowrap;text-decoration:none;border:1px solid transparent;font-family:inherit;cursor:pointer}
.hist-btn:hover{background:var(--it-gold);color:var(--it-forest-deep)}

/* history drawer — small quick action buttons (call/mail) inside person card */
.h-quick{width:36px;height:36px;border-radius:10px;display:inline-grid;place-items:center;transition:.13s;text-decoration:none;flex:0 0 auto;border:1px solid transparent}
.h-quick.call{background:var(--it-success-soft);color:var(--it-forest);border-color:#C5E3CF}
.h-quick.call:hover{background:#C5E3CF}
.h-quick.mail{background:var(--it-cream-2);color:var(--it-ink-2);border-color:var(--it-line)}
.h-quick.mail:hover{background:var(--it-gold-light);border-color:var(--it-gold);color:var(--it-forest)}

/* history drawer footer buttons override (use btn-clear/btn-search shape) */
#hist-drawer .btn-clear{flex:0 0 auto;height:40px}
#hist-drawer .btn-search{height:40px}
@media (max-width:1180px){
  .person{flex-wrap:wrap}
  .person .p-last{border-left:0;padding-left:0;width:auto}
}

@media (max-width:1100px){
  .sp-grid{grid-template-columns:1fr}
  .sp-field,.sp-field.full{grid-template-columns:110px 1fr}
}

/* projdetail block removed — proj_detail.asp now uses icons.co.th stylesheets via <base href> */

/* ============================================================
   Breadcrumb + Favorites/Calendar helper pills
   ============================================================ */

/* Page breadcrumb (firmfavorite, firmcalendar, future inner pages) */
.page-crumb{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--it-muted);margin:6px 0 14px;flex-wrap:wrap}
.page-crumb a{display:inline-flex;align-items:center;gap:6px;color:var(--it-forest);font-weight:600;text-decoration:none;padding:5px 10px;border-radius:18px;background:var(--it-cream-2);transition:background .15s,color .15s}
.page-crumb a:hover{background:var(--it-gold-light);color:var(--it-forest-deep)}
.page-crumb .sep{color:var(--it-muted-2);font-weight:400}

/* Favorites table — date column + symbol pills */
.fav-date-cell{color:var(--it-muted);font-size:13px;white-space:nowrap;font-family:var(--ff-num,inherit);font-variant-numeric:tabular-nums}
.fav-sym{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:14px;font-size:13px;font-weight:600;font-variant-numeric:tabular-nums}
.fav-sym.has{background:var(--it-gold-light);color:var(--it-forest-deep)}
.fav-sym.muted{background:var(--it-cream-2);color:var(--it-muted-2)}
.fav-sym svg{flex-shrink:0}
.fav-sym .fav-sym-date{font-weight:500;font-size:11.5px;color:var(--it-forest);padding-left:6px;margin-left:2px;border-left:1px solid rgba(14,77,44,.25)}

/* Calendar alert card — contact-history pill row replaces old r.note */
.a-hist{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.a-hist-pill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;color:var(--it-forest);background:var(--it-gold-light);padding:3px 9px;border-radius:11px;font-variant-numeric:tabular-nums}
.a-hist-pill svg{flex-shrink:0}
.a-hist-last{font-weight:500;color:var(--it-muted);padding-left:5px;margin-left:3px;border-left:1px solid rgba(107,107,107,.3)}

