/* =============================================================================
   南方潮 Design System — ds.css  (single source of truth for the prototype)
   屏東縣便民E櫃台 · Scottish-DS discipline + measured warmth
   Conventions: no gradients / no accent-stripes / yellow #fdd522 focus /
   radius 4(controls) 6(panels) 8(cards) / 2px control borders / functional colour.
   ========================================================================== */

/* ---- 1. TOKENS ---------------------------------------------------------- */
:root{
  /* named palette */
  --flame:#c4482e; --dusk:#af4029; --bashi:#16527a; --dapeng:#0c8188; --liuqiu:#4db9be;
  --forest:#168735; --paddy:#5b7801; --mango:#9f5d06; --sun:#c8770a; --sun-bright:#e8a300;
  --dragonfruit:#c2185b; --ink:#2b2b2b; --reef:#6b6266; --sand:#faf8f5; --sand-2:#f3efea;
  --line:#e7ddd5; --line-strong:#cbd3db;
  /* focus (Scottish/GDS signature) */
  --focus:#fdd522; --focus-ring:#1a1a1a;
  /* radius */
  --r-sm:4px; --r-md:6px; --r-lg:8px;
  --maxw:1180px;
  --sans:"PingFang TC","Noto Sans TC","Microsoft JhengHei",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  --mono:ui-monospace,Menlo,Consolas,monospace;
}

/* ---- 2. BASE ------------------------------------------------------------ */
*{box-sizing:border-box}
html{font-size:calc(16px * var(--fs,1));scroll-behavior:smooth}
body{margin:0;background:var(--sand);color:var(--ink);font-family:var(--sans);line-height:1.75;-webkit-font-smoothing:antialiased}
a{color:var(--bashi);text-underline-offset:.16em}
a:hover{color:var(--dusk)}
img{max-width:100%;display:block}
button{font:inherit}
:focus-visible{outline:3px solid var(--focus);outline-offset:0;box-shadow:0 0 0 5px var(--focus-ring)}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:22px;padding-right:22px}
.skip{position:absolute;left:-999px}
.skip:focus{left:12px;top:10px;background:#fff;padding:8px 14px;border-radius:var(--r-sm);z-index:99}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.ico{width:20px;height:20px;flex:none}
.ribbon{position:fixed;right:0;bottom:0;background:#11364f;color:#cfe0ee;font-size:.72rem;padding:5px 12px;border-radius:var(--r-lg) 0 0 0;z-index:50;opacity:.92}
main section{padding:46px 0}

/* ---- 3. BUTTONS --------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:10px 18px;border-radius:var(--r-sm);border:0;font:inherit;font-weight:700;cursor:pointer;text-decoration:none;white-space:nowrap}
.btn-primary{background:var(--flame);color:#fff}
.btn-primary:hover{background:var(--dusk);color:#fff}
.btn-ghost{background:#fff;color:var(--bashi);border:1.5px solid #d9cdc8}
.btn-ghost:hover{border-color:var(--bashi)}
.infocard .cta .btn{width:100%}

/* ---- 4. FRONT-OFFICE CHROME --------------------------------------------- */
.util{background:#11364f;color:#dce7ef;font-size:.82rem}
.util .wrap{display:flex;justify-content:flex-end;align-items:center;gap:6px;min-height:40px;flex-wrap:wrap}
.util a,.util button{color:#dce7ef;background:none;border:0;font:inherit;cursor:pointer;padding:6px 9px;border-radius:var(--r-sm);text-decoration:none}
.util a:hover,.util button:hover{background:rgba(255,255,255,.12);color:#fff}
.util .sep{opacity:.4}
.util .tag{margin-right:auto;opacity:.7;font-size:.76rem}
header.site{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}
header.site .wrap{display:flex;align-items:center;gap:18px;min-height:74px}
.brand{display:flex;align-items:center;gap:13px;text-decoration:none;color:var(--ink)}
.brand img{width:44px;height:44px}
.brand .t b{display:block;font-size:1.14rem;font-weight:800;letter-spacing:.5px;line-height:1.2;color:#11364f}
.brand .t span{font-size:.72rem;color:var(--reef);letter-spacing:.16em}
nav.main{margin-left:auto;display:flex;gap:4px}
nav.main a{padding:9px 14px;border-radius:var(--r-sm);font-weight:600;text-decoration:none;color:#3a4252}
nav.main a:hover,nav.main a[aria-current]{background:#eef2f6;color:var(--bashi)}
footer.site{background:#0e2f47;color:#cdddea;margin-top:10px}
footer.site .seam{display:block;width:100%}
footer.site .wrap{padding-top:28px;padding-bottom:36px;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:26px}
footer.site .fbrand{display:flex;gap:12px;align-items:flex-start}
footer.site .fbrand img{width:50px;height:50px;background:#fff;border-radius:var(--r-lg);padding:3px}
footer.site h3{font-size:.78rem;letter-spacing:.12em;color:#7fa6c2;margin:0 0 10px}
footer.site a{color:#cdddea;text-decoration:none;display:block;padding:4px 0;font-size:.9rem}
footer.site a:hover{color:#fff;text-decoration:underline}
footer.site .legal{border-top:1px solid rgba(255,255,255,.12);font-size:.8rem;color:#8fb0c9;padding:15px 22px;text-align:center}

/* ---- 5. SECTION HEADINGS ------------------------------------------------ */
.sec-head{display:flex;align-items:baseline;gap:14px;margin-bottom:6px}
.sec-head h2{font-size:1.5rem;margin:0;color:#11364f;letter-spacing:.5px}
.sec-head .en{color:var(--reef);font-size:.86rem;letter-spacing:.1em}
.sec-sub{color:var(--reef);margin:0 0 22px}

/* ---- 6. SERVICE-FLOW COMPONENT (shared: detail + flow editor) ----------- */
.flow{display:flex;margin:2px 0}
.flow.is-vertical{flex-direction:column}
.fstep{flex:1;min-width:96px;text-align:center;position:relative;padding:0 8px}
.fstep::after{content:"";position:absolute;top:29px;left:50%;width:100%;height:3px;background:var(--line-strong);z-index:0}
.fstep:last-child::after{display:none}
.node{width:60px;height:60px;border-radius:999px;border:2.5px solid var(--c);background:var(--cs);display:flex;align-items:center;justify-content:center;margin:0 auto;position:relative;z-index:1}
.node img{width:32px;height:32px}
.node .dot{width:14px;height:14px;border-radius:999px;background:var(--c)}
.num{position:absolute;top:-5px;right:-5px;width:21px;height:21px;border-radius:999px;background:var(--c);color:#fff;font-size:.68rem;font-weight:700;display:flex;align-items:center;justify-content:center}
.fbody{position:relative;z-index:1;margin-top:10px}
.ftype{display:inline-block;font-size:.72rem;font-weight:700;color:var(--c);background:var(--cs);padding:2px 10px;border-radius:999px}
.ftitle{font-weight:700;margin-top:8px;font-size:.92rem}
.fdesc{font-size:.82rem;color:var(--reef);margin-top:4px}
.fnote{font-size:.77rem;color:var(--mango);margin-top:7px;display:flex;gap:4px}
.flow:not(.is-vertical) .fnote{justify-content:center;text-align:left}
.flow.is-vertical .fstep{flex:none;min-width:0;display:grid;grid-template-columns:60px 1fr;gap:0 14px;text-align:left;padding:0 0 20px}
.flow.is-vertical .fstep::after{top:29px;left:29px;width:3px;height:100%}
.flow.is-vertical .node{margin:0}
.flow.is-vertical .fbody{margin-top:0;padding-top:2px}
.empty{color:var(--reef);text-align:center;padding:24px}

/* ---- 7. FAQ ACCORDION --------------------------------------------------- */
details{border:1px solid var(--line);border-radius:var(--r-md);margin:9px 0;background:#fff;overflow:hidden}
details[open]{border-color:#cfe0e1}
summary{cursor:pointer;padding:14px 16px;font-weight:600;list-style:none;display:flex;align-items:center;gap:10px}
summary::-webkit-details-marker{display:none}
summary .q{background:var(--dapeng);color:#fff;width:22px;height:22px;border-radius:var(--r-sm);font-size:.78rem;display:flex;align-items:center;justify-content:center;flex:none}
summary .chev{margin-left:auto;transition:transform .15s;color:var(--reef)}
details[open] summary .chev{transform:rotate(180deg)}
details .ans{padding:0 16px 15px 48px;color:#3a4150;font-size:.92rem}

/* ---- 8. TOAST ----------------------------------------------------------- */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);background:#11364f;color:#fff;padding:12px 22px;border-radius:var(--r-md);box-shadow:0 8px 24px rgba(0,0,0,.2);opacity:0;pointer-events:none;transition:.25s;z-index:60;font-weight:600;display:flex;gap:9px;align-items:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ============================ HOME (front) =============================== */
.hero{background:#fbf3e9;position:relative}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:center;padding:48px 22px 30px}
.hero h1{font-size:2.3rem;line-height:1.25;margin:0 0 12px;color:#10324a;letter-spacing:.5px}
.hero h1 .accent{color:var(--flame)}
.hero p.lead{font-size:1.08rem;color:#3f4a52;margin:0 0 22px;max-width:34em}
.bigsearch{display:flex;background:#fff;border-radius:var(--r-md);border:2px solid var(--line-strong);padding:7px;gap:7px;max-width:520px}
.bigsearch input{flex:1;border:0;outline:0;font:inherit;font-size:1.02rem;padding:0 14px;background:none}
.hero .hint{margin:14px 0 0;font-size:.9rem;color:var(--reef)}
.hero .hint a{font-weight:600}
.hero-art{justify-self:end}
.hero-art img{width:100%;max-width:560px;filter:drop-shadow(0 10px 22px rgba(17,54,79,.14))}
.wave-seam{display:block;width:100%;margin-top:-2px}
.hsearch{display:inline-flex;align-items:center;background:#fff;border:2px solid var(--line-strong);border-radius:var(--r-sm);padding:3px 4px 3px 14px}
.hsearch input{border:0;outline:0;font:inherit;font-size:.92rem;width:150px;background:none}
.hsearch button{border:0;background:var(--bashi);color:#fff;width:40px;height:40px;border-radius:3px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.cats{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.cat{display:flex;flex-direction:column;align-items:center;gap:9px;text-align:center;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 10px;text-decoration:none;color:var(--ink);transition:transform .12s,box-shadow .12s,border-color .12s}
.cat:hover{transform:translateY(-3px);box-shadow:0 8px 20px rgba(17,54,79,.10);border-color:#cfe0e1}
.cat img{width:46px;height:46px}
.cat b{font-size:.95rem;font-weight:700}
.cat small{color:var(--reef);font-size:.74rem;line-height:1.45}
.journeys{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.jcard{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:#fff;text-decoration:none;color:var(--ink);transition:transform .12s,box-shadow .12s}
.jcard:hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(17,54,79,.12)}
.jcard .pic{aspect-ratio:3/2;background:#eef3f2;display:flex;align-items:center;justify-content:center;overflow:hidden}
.jcard .pic img{width:100%;height:100%;object-fit:cover}
.jcard .body{padding:15px 18px}
.jcard .body b{font-size:1.12rem;display:flex;align-items:center;gap:8px}
.jcard .body p{margin:5px 0 0;color:var(--reef);font-size:.88rem}
.jcard .go{color:var(--flame);font-weight:700;font-size:.88rem;margin-top:10px;display:inline-flex;align-items:center;gap:5px}
.pop{display:grid;grid-template-columns:repeat(2,1fr);gap:10px 30px}
.pop a{display:flex;align-items:center;gap:12px;padding:13px 8px;border-bottom:1px solid var(--line);text-decoration:none;color:var(--ink)}
.pop a:hover{color:var(--bashi)}
.pop .dot{width:9px;height:9px;border-radius:999px;flex:none}
.migrant{background:#e6f1f1}
.migrant .wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:30px;align-items:center}
.migrant .art img{border-radius:var(--r-lg);width:100%}
.migrant h2{color:#0c5f64;font-size:1.5rem;margin:0 0 6px}
.langchips{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 18px}
.langchips span{background:#fff;border:1px solid #bfe0dd;color:#0c5f64;border-radius:999px;padding:6px 14px;font-size:.86rem;font-weight:600}
.migrant ul{margin:0;padding-left:0;list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:8px}
.migrant ul a{text-decoration:none;color:#114e52;font-weight:600;display:flex;gap:8px;align-items:center}
.ann{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ann a{background:#fff;border:1px solid var(--line);border-left:5px solid var(--mango);border-radius:var(--r-md);padding:15px 17px;text-decoration:none;color:var(--ink)}
.ann a:hover{box-shadow:0 6px 16px rgba(17,54,79,.08)}
.ann .date{font-size:.78rem;color:var(--reef);font-family:var(--mono)}
.ann b{display:block;margin-top:5px;font-size:.96rem;line-height:1.5}

/* ============================ DETAIL (front) ============================= */
.crumb{font-size:.85rem;color:var(--reef);padding:16px 0 4px}
.crumb a{color:var(--reef);text-decoration:none}
.crumb a:hover{color:var(--bashi)}
.crumb span{margin:0 7px;opacity:.5}
h1.title{font-size:1.9rem;margin:6px 0 4px;color:#10324a;letter-spacing:.5px}
.lede{color:var(--reef);margin:0 0 18px;max-width:46em}
.detail{display:grid;grid-template-columns:1fr 322px;gap:36px;align-items:start;padding:6px 0 50px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 24px;margin-bottom:20px}
.card h2{font-size:1.22rem;margin:0 0 4px;color:#11364f}
.card h2 .en{font-size:.78rem;color:var(--faint,#9a93a3);font-weight:400;letter-spacing:.08em;margin-left:8px}
.card .sub{color:var(--reef);font-size:.9rem;margin:0 0 16px}
.layout-toggle{font-size:.8rem;color:var(--reef);float:right;display:flex;gap:4px;align-items:center}
.layout-toggle b{background:#eef2f6;color:var(--bashi);border-radius:var(--r-sm);padding:2px 8px}
.docs{list-style:none;margin:0;padding:0}
.docs li{display:flex;align-items:flex-start;gap:11px;padding:11px 0;border-bottom:1px dashed var(--line)}
.docs li:last-child{border-bottom:0}
.docs .di{color:var(--forest);margin-top:2px}
.dl{margin-top:6px}
.dl a{display:inline-flex;align-items:center;gap:7px;background:var(--sand-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:7px 12px;text-decoration:none;color:var(--bashi);font-size:.86rem;font-weight:600}
.dl a:hover{border-color:var(--bashi)}
.dl .ft{color:var(--reef);font-weight:400;font-size:.78rem}
.rel{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.rel a{display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--ink);padding:4px 0}
.rel a:hover{color:var(--bashi)}
.rel .ext{color:var(--reef);font-size:.76rem}
.meta-foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--reef);font-size:.84rem;padding:6px 2px}
.meta-foot a{color:var(--bashi)}
aside.side{position:sticky;top:90px;display:grid;gap:16px}
.infocard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.infocard .hd{background:#16527a;color:#fff;padding:14px 18px;font-weight:700}
.infocard dl{margin:0;padding:14px 18px}
.infocard dt{font-size:.76rem;color:var(--reef);margin-top:10px}
.infocard dt:first-child{margin-top:0}
.infocard dd{margin:2px 0 0;font-weight:600;font-size:.95rem}
.infocard .yes{color:var(--forest)}
.infocard .cta{padding:0 18px 18px;display:grid;gap:10px}
.sidetitle{font-size:.78rem;letter-spacing:.1em;color:var(--reef);font-weight:700;margin:0 0 4px}

/* ============================ BACK OFFICE ================================ */
.botop{background:#11364f;color:#fff;position:sticky;top:0;z-index:30}
.botop .row{display:flex;align-items:center;gap:14px;padding:11px 22px}
.botop .logo{display:flex;align-items:center;gap:10px}
.botop .logo img{width:34px;height:34px;background:#fff;border-radius:var(--r-sm);padding:2px}
.botop .logo b{font-size:1rem;letter-spacing:.4px}
.botop .logo span{font-size:.72rem;color:#9fbdd4;border-left:1px solid #3a5570;padding-left:10px;margin-left:4px}
.crumb b{color:#fff}
.botop .crumb{color:#bcd2e4;font-size:.84rem;padding:0}
.botop .right{margin-left:auto;display:flex;align-items:center;gap:12px;font-size:.84rem;color:#cfe0ee}
.botop .user{display:flex;align-items:center;gap:8px}
.botop .user .av{width:28px;height:28px;border-radius:999px;background:#3b6ea5;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700}
.actionbar{background:#0e2c43;border-top:1px solid #234863;padding:9px 22px;display:flex;align-items:center;gap:10px}
.actionbar .sp{margin-left:auto;display:flex;gap:9px}
.actionbar .btn-ghost{background:transparent;color:#cfe0ee;border:1.5px solid #3f6588}
.actionbar .btn-ghost:hover{border-color:#79a6cc;color:#fff}
.badge{font-size:.76rem;font-weight:700;padding:3px 11px;border-radius:999px;background:#3a5067;color:#dbe7f1}
.badge.draft{background:#5a4a2a;color:#ffe6b3}
.badge.rev{background:#5a3a12;color:#ffd9a8}
.badge.pub{background:#1f5a39;color:#bff0d0}
.bo{display:grid;grid-template-columns:1fr 470px;gap:24px;max-width:1320px;margin:0 auto;padding:24px 22px 70px;align-items:start}
.panel{background:#fff;border:1px solid var(--line-strong);border-radius:var(--r-md);padding:20px 22px}
.panel h1{font-size:1.18rem;margin:0 0 3px;color:#11364f}
.panel .hint{color:var(--reef);font-size:.88rem;margin:0 0 16px}
.step{display:grid;grid-template-columns:24px 1fr;gap:10px;border:1px solid var(--line-strong);border-radius:var(--r-sm);background:#fff;padding:14px 16px;margin-bottom:12px;align-items:start}
.step.dragging{opacity:.4}
.step.over{box-shadow:0 0 0 2px var(--c)}
.sh{cursor:grab;color:#b7b0ac;font-size:1.05rem;text-align:center;padding-top:5px;user-select:none}
.sh:active{cursor:grabbing}
.srow{display:flex;align-items:center;gap:8px;margin-bottom:2px}
.snum{width:24px;height:24px;border-radius:999px;background:var(--c);color:#fff;font-size:.76rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex:none}
.stype{font:inherit;font-size:.85rem;font-weight:700;border:2px solid var(--line-strong);border-radius:var(--r-sm);padding:5px 9px;background:#fff;color:var(--ink);cursor:pointer}
.sactions{margin-left:auto;display:flex;gap:4px}
.ib{width:32px;height:32px;border:2px solid var(--line-strong);background:#fff;border-radius:var(--r-sm);cursor:pointer;color:var(--reef);font-size:.78rem;line-height:1}
.ib:hover:not(:disabled){border-color:var(--bashi);color:var(--bashi)}
.ib:disabled{opacity:.3;cursor:default}
.ib.del:hover{border-color:var(--flame);color:var(--flame)}
.stitle,.sdesc,.snote{width:100%;font:inherit;border:2px solid var(--line-strong);border-radius:var(--r-sm);padding:8px 10px;margin-top:8px;color:var(--ink)}
.stitle{font-weight:600}.snote{font-size:.85rem;color:var(--mango)}.sdesc{resize:vertical;line-height:1.6}
.stitle::placeholder,.sdesc::placeholder,.snote::placeholder{color:#ada6a2}
.addbtn{width:100%;border:2px dashed var(--line-strong);background:var(--sand);color:var(--bashi);border-radius:var(--r-sm);padding:13px;font-weight:700;cursor:pointer;margin-top:3px}
.addbtn:hover{border-color:var(--bashi);background:#eef4f8}
.pv{position:sticky;top:118px}
.pvbar{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.pvbar .t{font-weight:800;color:#11364f}
.pvbar .live{font-size:.72rem;font-weight:700;color:var(--forest);background:#e6f2ea;padding:2px 9px;border-radius:999px}
.toggle{margin-left:auto;display:inline-flex;border:1px solid var(--line-strong);border-radius:var(--r-sm);overflow:hidden}
.toggle button{background:#fff;border:0;padding:7px 13px;font-weight:600;font-size:.84rem;color:var(--reef);cursor:pointer}
.toggle button.on{background:var(--bashi);color:#fff}
.stage{background:#fbf9f6;border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:22px 20px;overflow-x:auto}
.pvnote{font-size:.8rem;color:var(--reef);margin:12px 2px 0;display:flex;gap:6px;align-items:flex-start}
.legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px;font-size:.78rem;color:var(--reef)}
.legend span{display:inline-flex;align-items:center;gap:6px}
.legend i{width:12px;height:12px;border-radius:999px;display:inline-block}

/* ---- RESPONSIVE --------------------------------------------------------- */
@media(max-width:960px){
  .bo{grid-template-columns:1fr}.pv{position:static}.actionbar{flex-wrap:wrap}.actionbar .sp{flex-wrap:wrap}
}
@media(max-width:900px){
  .hero .wrap{grid-template-columns:1fr}.hero-art{display:none}
  .cats{grid-template-columns:repeat(3,1fr)}.journeys{grid-template-columns:repeat(2,1fr)}
  .pop,.migrant .wrap,.ann,footer.site .wrap{grid-template-columns:1fr}
  nav.main,.hsearch{display:none}
  .detail{grid-template-columns:1fr}
  aside.side{position:static;order:-1}
}
@media(max-width:720px){
  /* flows WITHOUT explicit orientation (e.g. detail) collapse to vertical on mobile */
  .flow:not(.is-horizontal):not(.is-vertical){flex-direction:column}
  .flow:not(.is-horizontal):not(.is-vertical) .fstep{flex:none;min-width:0;display:grid;grid-template-columns:60px 1fr;gap:0 14px;text-align:left;padding:0 0 20px}
  .flow:not(.is-horizontal):not(.is-vertical) .fstep::after{top:29px;left:29px;width:3px;height:100%}
  .flow:not(.is-horizontal):not(.is-vertical) .node{margin:0}
  .flow:not(.is-horizontal):not(.is-vertical) .fbody{margin-top:0;padding-top:2px}
  .flow:not(.is-horizontal):not(.is-vertical) .fnote{justify-content:flex-start}
  .layout-toggle{display:none}
}
@media(max-width:640px){
  .crumb{display:none}.botop .logo span{display:none}.botop .right .user{font-size:.78rem}
}
@media(max-width:560px){
  .journeys{grid-template-columns:1fr}
  .jcard{display:flex;align-items:stretch}
  .jcard .pic{width:118px;aspect-ratio:1/1;flex:none}
  .jcard .body{flex:1;display:flex;flex-direction:column;justify-content:center}
  .jcard .body b{font-size:1rem;gap:6px}.jcard .body b img{width:20px;height:20px}
  .cats{grid-template-columns:repeat(2,1fr)}
}

/* ============================ PHASE 1 COMPONENTS ========================= */
/* ---- shared back-office shell (B2 / B3 / B4) ---------------------------- */
.bo-shell{display:grid;grid-template-columns:222px 1fr;max-width:1340px;margin:0 auto;min-height:calc(100vh - 53px)}
.bo-nav{background:#fff;border-right:1px solid var(--line);padding:16px 12px;position:sticky;top:53px;align-self:start;height:calc(100vh - 53px);overflow:auto}
.bo-nav .grp{font-size:.7rem;letter-spacing:.12em;color:var(--reef);font-weight:700;margin:16px 10px 6px}
.bo-nav .grp:first-child{margin-top:0}
.bo-nav a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r-sm);text-decoration:none;color:#3a4252;font-weight:600;font-size:.92rem}
.bo-nav a:hover{background:#eef2f6;color:var(--bashi)}
.bo-nav a[aria-current]{background:#e7eef4;color:var(--bashi)}
.bo-nav a .ico{width:18px;height:18px}
.bo-nav .badge-n{margin-left:auto;background:var(--flame);color:#fff;font-size:.7rem;font-weight:700;border-radius:999px;padding:1px 7px}
.bo-main{padding:24px 28px 60px;min-width:0}
.page-head{display:flex;align-items:flex-end;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.page-head h1{font-size:1.5rem;margin:0;color:#11364f}
.page-head .sub{color:var(--reef);font-size:.9rem}
.page-head .actions{margin-left:auto;display:flex;gap:9px}

/* ---- F2 listing --------------------------------------------------------- */
.listing{display:grid;grid-template-columns:228px 1fr;gap:30px;align-items:start;padding:6px 0 50px}
.filters{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;position:sticky;top:90px}
.filters h2{font-size:.8rem;letter-spacing:.08em;color:var(--reef);margin:0 0 10px;font-weight:700}
.filters .fgroup{margin-bottom:16px}
.filters .fgroup:last-child{margin-bottom:0}
.filters label{display:flex;align-items:center;gap:9px;padding:6px 0;font-size:.92rem;cursor:pointer;color:#3a4252}
.filters input{accent-color:var(--bashi);width:16px;height:16px;flex:none}
.filters .cnt{margin-left:auto;color:var(--reef);font-size:.8rem}
.results-top{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.results-top .n{color:var(--reef);font-size:.9rem}
.results-top .n b{color:var(--ink)}
.sortbar{margin-left:auto;display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--reef)}
.sortbar select{font:inherit;border:2px solid var(--line-strong);border-radius:var(--r-sm);padding:6px 10px;background:#fff;color:var(--ink);cursor:pointer}
.svc-list{display:grid;gap:12px}
.svc-card{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:17px 20px;text-decoration:none;color:var(--ink);transition:transform .12s,box-shadow .12s,border-color .12s}
.svc-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(17,54,79,.09);border-color:#cfe0e1}
.svc-card .r1{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.cdot{width:10px;height:10px;border-radius:999px;flex:none}
.svc-card .svc-cat{font-size:.76rem;color:var(--reef);font-weight:600}
.tag-on{font-size:.72rem;font-weight:700;color:var(--forest);background:#e6f2ea;border-radius:999px;padding:2px 10px;display:inline-flex;align-items:center;gap:4px}
.tag-off{font-size:.72rem;font-weight:600;color:var(--reef);background:var(--sand-2);border-radius:999px;padding:2px 10px}
.svc-card .r1 .tag-on,.svc-card .r1 .tag-off{margin-left:auto}
.svc-card b{font-size:1.12rem;color:#11364f}
.svc-card p{margin:4px 0 0;color:var(--reef);font-size:.9rem;line-height:1.6}
.svc-card .foot{margin-top:9px;font-size:.8rem;color:var(--reef);display:flex;gap:14px;flex-wrap:wrap}
.pager{display:flex;gap:6px;justify-content:center;margin-top:24px}
.pager a,.pager span{min-width:38px;height:38px;padding:0 6px;border:1px solid var(--line-strong);border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center;text-decoration:none;color:var(--bashi);font-weight:600;background:#fff}
.pager .on{background:var(--bashi);color:#fff;border-color:var(--bashi)}
.pager .dis{opacity:.4;pointer-events:none}
.empty-state{text-align:center;padding:38px 20px;color:var(--reef);background:#fff;border:1px solid var(--line);border-radius:var(--r-lg)}
.empty-state img{width:120px;margin:0 auto 14px;opacity:.92}

/* ---- F4 search ---------------------------------------------------------- */
.searchpage{background:#fbf3e9}
.searchpage .wrap{padding:28px 22px 24px}
.searchbox-lg{display:flex;background:#fff;border-radius:var(--r-md);border:2px solid var(--line-strong);padding:8px;gap:8px;max-width:680px;position:relative}
.searchbox-lg input{flex:1;border:0;outline:0;font:inherit;font-size:1.06rem;padding:0 14px;background:none}
.suggest{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--line-strong);border-radius:var(--r-md);box-shadow:0 10px 30px rgba(17,54,79,.14);z-index:20;overflow:hidden;display:none}
.suggest.show{display:block}
.suggest a{display:flex;align-items:center;gap:10px;padding:11px 16px;text-decoration:none;color:var(--ink);border-bottom:1px solid var(--line)}
.suggest a:last-child{border-bottom:0}
.suggest a:hover,.suggest a.act{background:#eef4f8}
.suggest .k{font-weight:600}.suggest .c{margin-left:auto;font-size:.78rem;color:var(--reef)}
.searchmeta{color:var(--reef);font-size:.92rem;margin:8px 2px 0}
.searchmeta b{color:#11364f}
.xling{display:flex;gap:10px;align-items:flex-start;background:#e6f1f1;border:1px solid #bfe0dd;border-radius:var(--r-md);padding:12px 16px;margin:16px 0;color:#0c5f64;font-size:.9rem}
.xling .ico{color:#0c8188;flex:none;margin-top:1px}
.result{display:block;padding:16px 4px;border-bottom:1px solid var(--line);text-decoration:none;color:var(--ink)}
.result:hover b{color:var(--bashi)}
.result .r1{display:flex;align-items:center;gap:10px;font-size:.78rem;color:var(--reef);margin-bottom:3px}
.result b{font-size:1.1rem;color:#11364f}
.result mark{background:#fde6b0;color:inherit;padding:0 1px;border-radius:2px}
.result p{margin:3px 0 0;color:var(--reef);font-size:.9rem}
.zero{text-align:center;padding:26px 20px}
.zero img{width:130px;margin:0 auto 12px}

/* ---- B1 login ----------------------------------------------------------- */
.login-page{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr}
.login-brand{background:#11364f;color:#fff;padding:54px 56px;display:flex;flex-direction:column;justify-content:center}
.login-brand img{width:62px;height:62px;background:#fff;border-radius:var(--r-lg);padding:5px;margin-bottom:22px}
.login-brand h1{font-size:1.9rem;margin:0 0 10px;letter-spacing:.5px}
.login-brand p{color:#a8c4da;max-width:30em;line-height:1.8;margin:0}
.login-brand .feat{margin-top:26px;display:grid;gap:12px}
.login-brand .feat div{display:flex;gap:10px;align-items:flex-start;color:#cfe0ee;font-size:.92rem}
.login-brand .feat .ico{color:#7fc6cb;flex:none;margin-top:1px}
.login-main{display:flex;align-items:center;justify-content:center;padding:40px 24px;background:var(--sand)}
.login-card{width:100%;max-width:380px}
.login-card h2{font-size:1.3rem;margin:0 0 4px;color:#11364f}
.login-card .sub{color:var(--reef);font-size:.9rem;margin:0 0 22px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;margin-bottom:6px;font-size:.92rem}
.field input{width:100%;border:2px solid var(--line-strong);border-radius:var(--r-sm);padding:11px 13px;font:inherit;color:var(--ink)}
.field input:focus{border-color:var(--bashi)}
.login-card .btn-primary{width:100%;margin-top:4px}
.ssorow{margin:22px 0 0;text-align:center;position:relative}
.ssorow::before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--line)}
.ssorow span{position:relative;background:var(--sand);padding:0 12px;color:var(--reef);font-size:.84rem}
.sso{display:grid;gap:10px;margin-top:18px}
.sso button{display:flex;align-items:center;gap:10px;width:100%;min-height:46px;padding:0 16px;border:2px solid var(--line-strong);background:#fff;border-radius:var(--r-sm);font:inherit;font-weight:600;color:#3a4252;cursor:pointer}
.sso button:hover{border-color:var(--bashi);color:var(--bashi)}
.sso .prov{margin-left:auto;font-size:.72rem;color:var(--reef);font-weight:400}

/* ---- B2 dashboard ------------------------------------------------------- */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.statcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px}
.statcard .n{font-size:1.9rem;font-weight:800;color:#11364f;line-height:1}
.statcard .l{color:var(--reef);font-size:.86rem;margin-top:6px}
.statcard.accent{border-left:4px solid var(--flame)}
.dash-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:22px;align-items:start}
.worklist,.activity{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.worklist .hd,.activity .hd{padding:14px 18px;border-bottom:1px solid var(--line);font-weight:700;color:#11364f;display:flex;align-items:center;gap:8px}
.worklist .hd .n{margin-left:auto;font-size:.78rem;color:var(--reef);font-weight:400}
.worklist a{display:flex;align-items:center;gap:12px;padding:13px 18px;border-bottom:1px solid var(--line);text-decoration:none;color:var(--ink)}
.worklist a:last-child{border-bottom:0}
.worklist a:hover{background:#f7fafc}
.worklist .t{font-weight:600}
.worklist .m{margin-left:auto;font-size:.8rem;color:var(--reef)}
.activity .it{display:flex;gap:11px;padding:12px 18px;border-bottom:1px solid var(--line);font-size:.9rem}
.activity .it:last-child{border-bottom:0}
.activity .dot{width:9px;height:9px;border-radius:999px;margin-top:7px;flex:none}
.activity .when{margin-left:auto;color:var(--reef);font-size:.8rem;white-space:nowrap}

/* ---- B3 CMS table ------------------------------------------------------- */
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.toolbar .search{display:inline-flex;align-items:center;gap:8px;border:2px solid var(--line-strong);border-radius:var(--r-sm);padding:7px 12px;background:#fff;flex:1;min-width:200px;max-width:320px}
.toolbar .search .ico{color:var(--reef);flex:none}
.toolbar .search input{border:0;outline:0;font:inherit;flex:1;background:none;color:var(--ink)}
.toolbar select{font:inherit;border:2px solid var(--line-strong);border-radius:var(--r-sm);padding:8px 10px;background:#fff;color:var(--ink);cursor:pointer}
.toolbar .sp{margin-left:auto}
.tablewrap{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
table.cms{width:100%;border-collapse:collapse;font-size:.92rem}
table.cms th,table.cms td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
table.cms thead th{background:#f7f4f0;color:var(--reef);font-size:.8rem;font-weight:700;letter-spacing:.03em}
table.cms tbody tr:hover{background:#f7fafc}
table.cms tbody tr:last-child td{border-bottom:0}
table.cms .title a{color:#11364f;font-weight:600;text-decoration:none}
table.cms .title a:hover{color:var(--bashi)}
table.cms .muted{color:var(--reef);font-size:.86rem}
table.cms input[type=checkbox]{accent-color:var(--bashi);width:16px;height:16px}
.batchbar{display:none;align-items:center;gap:14px;background:#eef4f8;border:1px solid #cfe0e1;border-radius:var(--r-sm);padding:9px 14px;margin-bottom:12px;font-size:.9rem}
.batchbar.show{display:flex}
.batchbar b{color:var(--bashi)}
.batchbar .sp{margin-left:auto;display:flex;gap:8px}
.transbar{display:inline-flex;align-items:center;gap:7px}
.transbar .bar{width:60px;height:7px;border-radius:999px;background:var(--line);overflow:hidden}
.transbar .bar i{display:block;height:100%;background:var(--forest)}
.transbar .pct{font-size:.78rem;color:var(--reef)}
.st-badge{font-size:.74rem;font-weight:700;padding:2px 10px;border-radius:999px;white-space:nowrap}
.st-published{background:#e6f2ea;color:#1f6a3a}
.st-review{background:#fbe7d2;color:#8a5012}
.st-draft{background:var(--sand-2);color:var(--reef)}

/* ---- B4 editor tabs ----------------------------------------------------- */
.tabs{display:flex;gap:2px;border-bottom:2px solid var(--line);margin-bottom:22px;flex-wrap:wrap}
.tab{appearance:none;background:none;border:0;border-bottom:3px solid transparent;margin-bottom:-2px;padding:11px 16px;font:inherit;font-weight:600;color:var(--reef);cursor:pointer;display:inline-flex;align-items:center;gap:7px}
.tab:hover{color:var(--bashi)}
.tab[aria-selected="true"]{color:var(--flame);border-bottom-color:var(--flame)}
.tab .warn{width:8px;height:8px;border-radius:999px;background:var(--mango)}
.tabpanel{display:none}
.tabpanel.show{display:block}
.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:760px}
.formgrid .full{grid-column:1/-1}
.formgrid label{display:block;font-weight:600;margin-bottom:6px;font-size:.92rem}
.formgrid input,.formgrid textarea,.formgrid select{width:100%;border:2px solid var(--line-strong);border-radius:var(--r-sm);padding:10px 12px;font:inherit;color:var(--ink)}
.formgrid input:focus,.formgrid textarea:focus,.formgrid select:focus{border-color:var(--bashi)}
.formgrid textarea{resize:vertical;line-height:1.6}
.formgrid .hint{font-size:.82rem;color:var(--reef);margin-top:5px;font-weight:400}
.langtable{width:100%;border-collapse:collapse}
.langtable th,.langtable td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line)}
.langtable thead th{font-size:.8rem;color:var(--reef);font-weight:700}
.langtable tbody tr:last-child td{border-bottom:0}
.lang-done{color:var(--forest);font-weight:600}
.lang-partial{color:var(--mango);font-weight:600}
.lang-none{color:var(--reef)}

/* ---- phase-1 responsive ------------------------------------------------- */
@media(max-width:960px){
  .bo-shell{grid-template-columns:1fr}
  .bo-nav{position:static;height:auto;display:flex;flex-wrap:wrap;gap:4px;border-right:0;border-bottom:1px solid var(--line)}
  .bo-nav .grp{display:none}
  .stat-row{grid-template-columns:repeat(2,1fr)}
  .dash-grid{grid-template-columns:1fr}
}
@media(max-width:820px){
  .login-page{grid-template-columns:1fr}
  .login-brand{display:none}
  .listing{grid-template-columns:1fr}
  .filters{position:static}
}
@media(max-width:640px){
  .formgrid{grid-template-columns:1fr}
  .stat-row{grid-template-columns:1fr 1fr}
  table.cms .hide-sm{display:none}
}

/* ============================ PHASE 2 COMPONENTS ========================= */
/* ---- F5 新住民 gateway --------------------------------------------------- */
.nr-hero{background:#e6f1f1}
.nr-hero .wrap{display:grid;grid-template-columns:1fr .8fr;gap:30px;align-items:center;padding:36px 22px}
.nr-hero h1{font-size:1.9rem;margin:0 0 6px;color:#0c5f64;letter-spacing:.5px}
.nr-hero .sub{color:#2e6469;margin:0 0 16px}
.nr-greeting{background:#fff;border:1px solid #bfe0dd;border-radius:var(--r-md);padding:14px 18px;color:#114e52;font-size:1.02rem;line-height:1.7;min-height:3.4em}
.lang-picker{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0 0}
.lang-picker button{font:inherit;font-weight:600;font-size:.9rem;border:2px solid #bfe0dd;background:#fff;color:#0c5f64;border-radius:999px;padding:7px 16px;cursor:pointer}
.lang-picker button:hover{border-color:#0c8188}
.lang-picker button[aria-pressed="true"]{background:#0c8188;color:#fff;border-color:#0c8188}
.nr-hero .art img{width:100%;border-radius:var(--r-lg)}
.nr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.nr-card{display:flex;flex-direction:column;gap:6px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 20px;text-decoration:none;color:var(--ink);transition:transform .12s,box-shadow .12s,border-color .12s}
.nr-card:hover{transform:translateY(-3px);box-shadow:0 8px 20px rgba(12,129,136,.12);border-color:#bfe0dd}
.nr-card img{width:40px;height:40px}
.nr-card b{font-size:1.08rem;color:#11364f}
.nr-card .vi{font-size:.82rem;color:#0c8188;font-weight:600}
.nr-card p{margin:4px 0 0;color:var(--reef);font-size:.88rem;line-height:1.6}
.nr-hotline{background:#fbf3e9;border:1px solid #efe2cf;border-radius:var(--r-lg);padding:18px 22px;display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.nr-hotline .ico{color:var(--flame);flex:none}
.nr-hotline b{color:#11364f}

/* ---- F6 form (GDS-style validation) ------------------------------------- */
.formpage{max-width:680px}
.fld{margin-bottom:22px}
.fld>label{display:block;font-weight:700;margin-bottom:4px;font-size:1rem}
.fld .hint{color:var(--reef);font-size:.88rem;margin:0 0 8px}
.fld input,.fld select,.fld textarea{width:100%;border:2px solid var(--line-strong);border-radius:var(--r-sm);padding:11px 13px;font:inherit;color:var(--ink)}
.fld input:focus,.fld select:focus,.fld textarea:focus{border-color:var(--bashi)}
.fld textarea{resize:vertical;line-height:1.6}
.fld .err{display:none;color:#b4231a;font-weight:600;font-size:.9rem;margin:0 0 8px}
.fld.bad .err{display:block}
.fld.bad>label{color:#b4231a}
.fld.bad input,.fld.bad select,.fld.bad textarea{border-color:#b4231a}
.fld.bad{border-left:4px solid #b4231a;padding-left:16px;margin-left:-20px}
.radios{display:grid;gap:8px;margin-top:4px}
.radios label,.checkrow label{display:flex;align-items:center;gap:10px;font-weight:400;cursor:pointer}
.radios input,.checkrow input{width:18px;height:18px;accent-color:var(--bashi);flex:none}
.error-summary{display:none;border:2px solid #b4231a;border-radius:var(--r-md);padding:16px 20px;margin-bottom:24px;background:#fdf1f0}
.error-summary.show{display:block}
.error-summary h2{color:#b4231a;font-size:1.05rem;margin:0 0 8px}
.error-summary ul{margin:0;padding-left:20px}
.error-summary a{color:#b4231a;font-weight:600}
.success-panel{display:none;border:2px solid var(--forest);border-radius:var(--r-md);background:#eaf6ee;padding:26px 28px;text-align:center}
.success-panel.show{display:block}
.success-panel .ico{color:var(--forest);width:48px;height:48px;margin:0 auto 10px}
.success-panel h2{color:#1f6a3a;margin:0 0 6px}
.success-panel p{color:#2f6b3d;margin:0}

/* ---- F7 i18n fallback marker -------------------------------------------- */
.fallback{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:700;color:#8a5012;background:#fbe7d2;border-radius:var(--r-sm);padding:2px 9px;margin-left:8px;vertical-align:middle}

/* ---- B6 category tree --------------------------------------------------- */
.tree{display:grid;gap:8px;max-width:820px}
.tnode{border:1px solid var(--line-strong);border-radius:var(--r-md);background:#fff;overflow:hidden}
.thead{display:flex;align-items:center;gap:12px;padding:12px 14px}
.thead .tdrag{color:#b7b0ac;cursor:grab;font-size:1.05rem;user-select:none}
.thead .tname{font-weight:700;color:#11364f}
.thead .tcount{color:var(--reef);font-size:.82rem}
.thead .texpand{margin-left:auto;background:none;border:0;color:var(--reef);cursor:pointer;font:inherit;display:flex;align-items:center;gap:5px}
.thead .tacts{display:flex;gap:5px}
.tkids{display:none;border-top:1px dashed var(--line);padding:6px 14px 10px 44px}
.tnode.open .tkids{display:block}
.tkid{display:flex;align-items:center;gap:10px;padding:7px 0;color:#3a4252;font-size:.92rem;border-bottom:1px solid var(--line)}
.tkid:last-child{border-bottom:0}
.tkid .kdot{width:7px;height:7px;border-radius:999px;background:var(--reef);flex:none}

/* ---- B7 media library --------------------------------------------------- */
.upload-zone{border:2px dashed var(--line-strong);border-radius:var(--r-md);background:var(--sand);padding:24px;text-align:center;color:var(--reef);margin-bottom:20px;cursor:pointer}
.upload-zone:hover{border-color:var(--bashi);background:#eef4f8}
.upload-zone b{color:var(--bashi)}
.media-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.mcard{border:1px solid var(--line);border-radius:var(--r-lg);background:#fff;overflow:hidden;cursor:pointer;transition:box-shadow .12s,border-color .12s}
.mcard:hover{box-shadow:0 6px 16px rgba(17,54,79,.1);border-color:#cfe0e1}
.mthumb{height:92px;display:flex;align-items:center;justify-content:center;color:#fff}
.mthumb.image{background:#0c8188}.mthumb.pdf{background:#c4482e}.mthumb.odt{background:#16527a}.mthumb.doc{background:#16527a}
.mthumb .ico{width:34px;height:34px}
.mname{padding:10px 12px 2px;font-size:.86rem;font-weight:600;color:#11364f;word-break:break-all}
.mmeta{padding:0 12px 12px;font-size:.76rem;color:var(--reef)}

/* ---- B8/B9 split + roles ------------------------------------------------ */
.bo-split{display:grid;grid-template-columns:1fr 290px;gap:22px;align-items:start}
.sidecard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.sidecard .hd{padding:13px 16px;border-bottom:1px solid var(--line);font-weight:700;color:#11364f}
.sidecard .srow{display:flex;align-items:center;gap:10px;padding:11px 16px;border-bottom:1px solid var(--line);font-size:.9rem}
.sidecard .srow:last-child{border-bottom:0}
.sidecard .srow .n{margin-left:auto;color:var(--reef);font-size:.82rem}
.role-pill{font-size:.74rem;font-weight:700;padding:2px 10px;border-radius:999px;background:#e7eef4;color:var(--bashi);white-space:nowrap}
.st-active{background:#e6f2ea;color:#1f6a3a}
.st-pending{background:#fbe7d2;color:#8a5012}
.st-disabled{background:var(--sand-2);color:var(--reef)}
.role-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:26px}
.role-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 20px}
.role-card .rt{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.role-card h3{font-size:1.1rem;margin:0;color:#11364f}
.role-card .scope{font-size:.74rem;font-weight:700;color:var(--dapeng);background:#e3f0f1;border-radius:999px;padding:2px 10px}
.role-card .count{margin-left:auto;color:var(--reef);font-size:.82rem}
.role-card .desc{color:var(--reef);font-size:.88rem;margin:0 0 10px}
.role-card ul{margin:0;padding-left:0;list-style:none;display:grid;gap:6px}
.role-card li{display:flex;gap:8px;align-items:flex-start;font-size:.88rem;color:#3a4252}
.role-card li .ico{color:var(--forest);flex:none;margin-top:1px;width:16px;height:16px}

/* ---- B10 audit type badges ---------------------------------------------- */
.audit-type{font-size:.74rem;font-weight:700;padding:2px 10px;border-radius:var(--r-sm);white-space:nowrap}
.audit-type.login{background:#e7eef4;color:#16527a}
.audit-type.publish{background:#e6f2ea;color:#1f6a3a}
.audit-type.perm{background:#fbe1ea;color:#a01050}
.audit-type.content{background:#f5ecdd;color:#8a5012}
.audit-type.system{background:var(--sand-2);color:var(--reef)}

/* ---- phase-2 responsive ------------------------------------------------- */
@media(max-width:900px){
  .nr-hero .wrap{grid-template-columns:1fr}.nr-hero .art{display:none}
  .nr-grid{grid-template-columns:repeat(2,1fr)}
  .media-grid{grid-template-columns:repeat(3,1fr)}
  .bo-split{grid-template-columns:1fr}
  .role-cards{grid-template-columns:1fr}
}
@media(max-width:640px){
  .nr-grid{grid-template-columns:1fr}.media-grid{grid-template-columns:repeat(2,1fr)}
}

/* ============================ PHASE 3 COMPONENTS ========================= */
/* ---- F8 規範／政策頁 ---------------------------------------------------- */
.policy{display:grid;grid-template-columns:230px 1fr;gap:36px;align-items:start;padding:6px 0 50px}
.toc{position:sticky;top:90px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:12px 8px}
.toc a{display:block;padding:8px 14px;border-radius:var(--r-sm);text-decoration:none;color:#3a4252;font-size:.9rem;font-weight:600;border-left:3px solid transparent}
.toc a:hover{background:#eef2f6;color:var(--bashi)}
.toc a.on{border-left-color:var(--flame);color:var(--flame);background:#fbf3e9}
.prose section{padding:4px 0 26px;border-bottom:1px solid var(--line);margin-bottom:26px;scroll-margin-top:90px}
.prose section:last-child{border-bottom:0}
.prose h2{font-size:1.35rem;color:#11364f;margin:0 0 12px}
.prose h3{font-size:1.02rem;color:#11364f;margin:18px 0 6px}
.prose p{margin:0 0 12px;color:#3f4a52}
.prose ul{margin:0 0 12px;padding-left:22px;color:#3f4a52}
.prose li{margin-bottom:6px}
.prose .updated{color:var(--reef);font-size:.84rem}
.sitemap{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.sitemap h3{margin:0 0 8px}
.sitemap a{display:block;padding:5px 0;color:var(--bashi);text-decoration:none;font-size:.92rem}
.sitemap a:hover{text-decoration:underline}

/* ---- 404 + F9 外部跳轉過場 --------------------------------------------- */
.centered{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:40px 22px}
.centered .inner{max-width:540px}
.centered .big{font-size:4rem;font-weight:800;color:var(--flame);line-height:1;letter-spacing:1px}
.centered h1{font-size:1.6rem;color:#11364f;margin:14px 0 8px}
.centered p{color:var(--reef);margin:0 0 22px;line-height:1.8}
.acts{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.interstitial-card{max-width:540px;margin:48px auto;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:34px 36px;text-align:center}
.interstitial-card .ico{width:52px;height:52px;color:var(--mango);margin:0 auto 14px}
.interstitial-card h1{font-size:1.4rem;color:#11364f;margin:0 0 8px}
.interstitial-card p{color:var(--reef);margin:0 0 8px;line-height:1.8}
.interstitial-card .dest{display:inline-block;background:var(--sand-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:8px 14px;font-family:var(--mono);font-size:.86rem;color:#11364f;margin:6px 0 18px;word-break:break-all}

/* ---- B11 settings ------------------------------------------------------- */
.setting-sec{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:4px 22px;margin-bottom:22px;max-width:840px}
.setting-sec>h2{font-size:1.1rem;color:#11364f;margin:18px 2px 2px}
.setting-row{display:flex;align-items:center;gap:18px;padding:16px 0;border-bottom:1px solid var(--line)}
.setting-row:last-child{border-bottom:0}
.setting-row .lbl{font-weight:600;color:#11364f}
.setting-row .desc{color:var(--reef);font-size:.86rem;margin-top:2px}
.setting-row .ctl{margin-left:auto;flex:none}
.setting-row select,.setting-row input[type=number],.setting-row input[type=text]{font:inherit;border:2px solid var(--line-strong);border-radius:var(--r-sm);padding:8px 10px;background:#fff;color:var(--ink)}
.lang-toggles{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.lang-toggles label{display:inline-flex;align-items:center;gap:7px;border:2px solid var(--line-strong);border-radius:999px;padding:6px 14px;font-size:.88rem;font-weight:600;cursor:pointer;color:#3a4252}
.lang-toggles label:has(input:checked){background:#e7eef4;border-color:var(--bashi);color:var(--bashi)}
.lang-toggles input{accent-color:var(--bashi);width:15px;height:15px}

/* ---- B12 authprovider --------------------------------------------------- */
.provider-switch{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}
.provider-switch button{font:inherit;font-weight:700;border:2px solid var(--line-strong);background:#fff;color:#3a4252;border-radius:var(--r-sm);padding:9px 16px;cursor:pointer}
.provider-switch button:hover{border-color:var(--bashi);color:var(--bashi)}
.provider-switch button[aria-pressed="true"]{background:var(--bashi);color:#fff;border-color:var(--bashi)}
.provider-note{color:var(--reef);font-size:.9rem;margin:0 0 18px;max-width:760px;background:#eef4f8;border:1px solid #cfe0e1;border-radius:var(--r-sm);padding:11px 15px}

/* ---- component gallery -------------------------------------------------- */
.gsec{margin-bottom:38px}
.gsec>h2{font-size:1.25rem;color:#11364f;margin:0 0 4px}
.gsec>.gsub{color:var(--reef);margin:0 0 16px}
.swatches{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.swatch{border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;background:#fff}
.swatch .chip{height:62px}
.swatch .meta{padding:8px 10px}
.swatch .nm{font-weight:700;font-size:.82rem;color:#11364f}
.swatch .hex{font-family:var(--mono);font-size:.72rem;color:var(--reef)}
.demo-box{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 24px}
.demo-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:14px}
.demo-row:last-child{margin-bottom:0}
.type-row{display:flex;align-items:baseline;gap:16px;padding:8px 0;border-bottom:1px solid var(--line)}
.type-row:last-child{border-bottom:0}
.type-row .tk{color:var(--reef);font-size:.8rem;font-family:var(--mono);width:130px;flex:none}
.icon-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:14px}
.icon-grid .ig{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}
.icon-grid img{width:34px;height:34px}
.icon-grid span{font-size:.7rem;color:var(--reef)}

@media(max-width:900px){
  .policy{grid-template-columns:1fr}.toc{position:static;display:flex;flex-wrap:wrap;gap:4px}
  .toc a{border-left:0}.sitemap{grid-template-columns:1fr 1fr}
  .swatches{grid-template-columns:repeat(4,1fr)}.icon-grid{grid-template-columns:repeat(6,1fr)}
}
@media(max-width:560px){
  .swatches{grid-template-columns:repeat(2,1fr)}.icon-grid{grid-template-columns:repeat(4,1fr)}.sitemap{grid-template-columns:1fr}
}

/* ---- presenter tour bar (?tour=N) -------------------------------------- */
body.has-tour{padding-bottom:66px}
.tourbar{position:fixed;left:0;right:0;bottom:0;background:#11364f;color:#fff;z-index:70;display:flex;align-items:center;gap:16px;padding:11px 20px;box-shadow:0 -4px 16px rgba(0,0,0,.18)}
.tourbar .tstep{font-family:var(--mono);font-size:.76rem;color:#9fbdd4;flex:none;white-space:nowrap}
.tourbar .say{color:#cfe0ee;font-size:.9rem;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tourbar .say .ti{font-weight:700;color:#fff}
.tourbar .nav{display:flex;gap:8px;flex:none}
.tourbar a{font:inherit;font-weight:700;border-radius:var(--r-sm);padding:8px 14px;text-decoration:none;font-size:.86rem;white-space:nowrap}
.tourbar a.prev{background:transparent;color:#cfe0ee;border:1.5px solid #3f6588}
.tourbar a.prev:hover{border-color:#79a6cc;color:#fff}
.tourbar a.next{background:var(--flame);color:#fff}
.tourbar a.next:hover{background:var(--dusk)}
.tourbar a.end{background:transparent;color:#9fbdd4;border:0;padding:8px 6px}
.tourbar a.dis{opacity:.4;pointer-events:none}
@media(max-width:720px){.tourbar .say{display:none}}
