/* ════════════════════════════════════════════════════════════
   街聲周邊申請 · 自有設計系統（取代 SV bootstrap，px by px）
   taste + ui-ux-pro：4/8 間距、單一街聲紅、一致圓角、完整狀態、a11y
   ──  SV 僅作參考：品牌紅 #f9595f、PingFang/Noto 字體、logo 資產
   ════════════════════════════════════════════════════════════ */

:root{
  /* brand */
  --red:#f9595f; --red-700:#e23b42; --red-50:#fff1f1; --red-100:#ffe1e2;
  /* neutral */
  --ink:#18181d; --ink-2:#3c3c45; --muted:#71717a; --faint:#a6a6af;
  --line:#ececf1; --line-2:#dcdce3; --bg:#f6f6f8; --surface:#fff;
  /* semantic */
  --green:#15936a; --green-50:#e6f6ee; --amber:#9a6a06; --amber-50:#fbeed2;
  --danger:#d23b3b; --danger-50:#fdecec;
  /* radius */
  --r-xs:8px; --r-sm:10px; --r:12px; --r-lg:16px; --r-xl:20px; --pill:999px;
  /* elevation */
  --shadow:0 1px 2px rgba(20,20,30,.04), 0 10px 28px -14px rgba(20,20,30,.12);
  --shadow-hover:0 2px 4px rgba(20,20,30,.05), 0 14px 32px -14px rgba(20,20,30,.2);
}

/* ── reset / base ─────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"PingFang TC","Noto Sans TC",system-ui,"Segoe UI",Roboto,"Helvetica Neue",sans-serif;
  font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:.01em}
img{max-width:100%;display:block}
button{font-family:inherit}
a{color:inherit;text-decoration:none}
hr{border:0;border-top:1px solid var(--line);margin:1rem 0}
:focus-visible{outline:none}

/* ── typography ───────────────────────────────────── */
h1{font-size:29px;line-height:1.22;font-weight:700;letter-spacing:-.01em;margin:0}
h2{font-size:19px;line-height:1.35;font-weight:700;margin:0}
h3{font-size:16px;line-height:1.4;font-weight:700;margin:0}
h4{font-size:14px;line-height:1.4;font-weight:600;margin:0}
h5{font-size:13px;font-weight:600;margin:0}
p{margin:0 0 .5rem}
small{font-size:85%}
.text-muted{color:var(--muted)}
.text-red{color:var(--red)}
.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}
.font-size-sm{font-size:13px}
.font-weight-bold{font-weight:700}
.align-middle{vertical-align:middle}
.d-block{display:block}.d-inline-flex{display:inline-flex}

/* ── layout: container / grid ─────────────────────── */
.container{width:100%;max-width:1140px;margin-inline:auto;padding-inline:20px}
@media(max-width:767px){.container{padding-inline:16px}}
.row{display:flex;flex-wrap:wrap;margin-inline:-10px}
.row > [class*="col"]{padding-inline:10px}
.no-gutters{margin-inline:0}
.no-gutters > [class*="col"]{padding-inline:0}
.col{flex:1 1 0;min-width:0}
.col-auto{flex:0 0 auto;width:auto;max-width:100%}
.col-6{flex:0 0 50%;max-width:50%}
.col-12{flex:0 0 100%;max-width:100%}
/* col-md/-lg：行動優先，預設滿版 */
.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-8,.col-lg-3,.col-lg-8,.col-lg-9{flex:0 0 100%;max-width:100%}
@media(min-width:768px){
  .col-md-3{flex:0 0 25%;max-width:25%}
  .col-md-4{flex:0 0 33.333%;max-width:33.333%}
  .col-md-5{flex:0 0 41.666%;max-width:41.666%}
  .col-md-6{flex:0 0 50%;max-width:50%}
  .col-md-8{flex:0 0 66.666%;max-width:66.666%}
}
@media(min-width:992px){
  .col-lg-3{flex:0 0 25%;max-width:25%}
  .col-lg-8{flex:0 0 66.666%;max-width:66.666%}
  .col-lg-9{flex:0 0 75%;max-width:75%}
  .minh-100vh-lg{min-height:60vh}
}
.mx-auto{margin-inline:auto}

/* flex utils */
.d-flex{display:flex}
.align-items-center{align-items:center}
.align-items-end{align-items:flex-end}
.justify-content-between{justify-content:space-between}
.justify-content-center{justify-content:center}
.mr-auto{margin-right:auto}.ml-auto{margin-left:auto}

/* ── spacing scale (0 .25 .5 1 1.5 2.5 3.5 / 4 6rem) ── */
.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}.mb-4{margin-bottom:1.5rem}.mb-5{margin-bottom:2.5rem}.mb-6{margin-bottom:3.5rem}
.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}.mt-5{margin-top:2.5rem}
.mr-2{margin-right:.5rem}.mr-3{margin-right:1rem}.ml-3{margin-left:1rem}
.my-6{margin-top:3.5rem;margin-bottom:3.5rem}
.pl-0{padding-left:0}.pl-3{padding-left:1rem}
.pt-4{padding-top:1.5rem}.pt-5{padding-top:2.5rem}
.pb-10{padding-bottom:4rem}
.py-1{padding-block:.25rem}.py-2{padding-block:.5rem}.py-3{padding-block:.75rem}.py-5{padding-block:2.5rem}

/* ── navbar ───────────────────────────────────────── */
.navbar{background:var(--surface);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;flex-wrap:nowrap;min-width:0;min-height:60px}
.navbar-brand{display:block;width:165px;height:20px;flex:0 0 auto;
  background:url("sv/images/logo-sv-b.svg") no-repeat center/165px 20px;text-indent:-9999px;overflow:hidden}
.navbar-text{color:var(--muted)}
.nav-label{margin-right:auto;margin-left:14px;white-space:nowrap}
.nav-user{display:flex;align-items:center;gap:10px;flex:0 0 auto;min-width:0}
.nav-user img{flex:0 0 auto}
.nav-name{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:42vw}
@media(max-width:575px){.nav-label{display:none}.nav-name{display:none}}

/* ── buttons ──────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:1px solid transparent;border-radius:var(--r);padding:10px 20px;
  font-size:14.5px;font-weight:600;line-height:1.2;white-space:nowrap;cursor:pointer;
  transition:background .15s,border-color .15s,transform .12s,box-shadow .15s;-webkit-appearance:none;background:none}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-700)}
.btn-white{background:#eff0f3;color:var(--ink-2)}
.btn-white:hover{background:#e6e7ec;color:var(--ink)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{filter:brightness(.94)}
.btn-link{background:none;border:0;color:var(--red);padding:6px 4px;font-weight:600}
.btn-link:hover{color:var(--red-700);text-decoration:underline}
.btn-lg{padding:13px 24px;font-size:15.5px;border-radius:14px}
.btn-sm{padding:7px 14px;font-size:13.5px;border-radius:var(--r-sm)}
.btn-block{display:flex;width:100%}
.nav-user .btn{border-radius:var(--pill);padding:7px 16px;line-height:1}

/* ── forms ────────────────────────────────────────── */
.form-group{margin-bottom:1rem}
.form-group > label{display:block;font-size:13px;font-weight:600;color:var(--ink-2);margin-bottom:6px}
.form-control{display:block;width:100%;padding:11px 14px;font-size:15px;color:var(--ink);
  background:var(--surface);border:1.5px solid var(--line-2);border-radius:var(--r);
  transition:border-color .15s,box-shadow .15s;-webkit-appearance:none}
.form-control::placeholder{color:var(--faint)}
.form-control:hover{border-color:#cfcfd8}
.form-control:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px var(--red-50)}
.form-control[readonly]{background:var(--surface);cursor:pointer}
textarea.form-control{min-height:96px;line-height:1.6;resize:vertical}
.form-row{display:flex;flex-wrap:wrap;margin-inline:-6px}
.form-row > [class*="col"]{padding-inline:6px}
.form-text{font-size:12.5px;color:var(--muted);margin-top:5px}
.form-text.text-red{color:var(--red)}

/* ── card (border-block) ──────────────────────────── */
.border-block{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);padding:26px;box-shadow:var(--shadow)}
@media(max-width:767px){.border-block{padding:20px;border-radius:var(--r-lg)}}

/* ── list：分離卡片（不黏在一起）─────────────────── */
.list-group{display:flex;flex-direction:column;gap:10px}
.list-group-item{display:flex;width:100%;text-align:left;background:var(--surface);
  border:1px solid var(--line);border-radius:14px;padding:14px 16px;color:inherit;font:inherit}
button.list-group-item{cursor:pointer;-webkit-appearance:none}
.list-group-item-action{transition:border-color .14s,box-shadow .14s,transform .12s;cursor:pointer}
.list-group.clickable .list-group-item-action:hover,.list-group-item-action:hover{border-color:#d4d4dc;box-shadow:var(--shadow-hover)}
.list-group-item-action:active{transform:scale(.997)}
/* 側欄選單：垂直 nav，非卡片 */
.list-group-menu{gap:2px}
.list-group-menu .list-group-item{display:flex;align-items:center;justify-content:space-between;
  background:none;border:0;border-radius:0;padding:.5rem .25rem .5rem .6rem;font-size:15px;color:var(--ink-2);
  border-left:2px solid transparent}
.list-group-menu .list-group-item-action:hover{box-shadow:none;border-color:transparent;border-left-color:var(--red);color:var(--red)}
.list-group-menu .list-group-item.active{color:var(--red);font-weight:600;border-left:2px solid var(--red)}

/* ── badges ───────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;justify-content:center;font-size:11.5px;font-weight:600;
  padding:4px 10px;border-radius:7px;white-space:nowrap;line-height:1.4}
.badge-pill{border-radius:var(--pill)}
.badge-gray-light{background:#eceef1;color:var(--muted)}
.badge-primary{background:var(--red);color:#fff}
.badge-white{background:#fff;color:var(--ink-2)}
.badge-warn{background:var(--amber-50);color:var(--amber)}

/* ── state pill（登入頁狀態）──────────────────────── */
.state-pill{flex:none;font-size:12px;font-weight:600;padding:5px 12px;border-radius:var(--pill);white-space:nowrap}
.pill-active{background:var(--red-50);color:var(--red-700)}
.pill-done{background:var(--green-50);color:var(--green)}
.pill-muted{background:#eef0f2;color:#8a8a93}
.pill-warn{background:var(--amber-50);color:var(--amber)}
.pill-staff{background:#1f1f26;color:#fff}

/* ── wizard / stepper ─────────────────────────────── */
.wizard .no-gutters{display:flex}
.wizard .col{position:relative;text-align:center}
.step-label{display:block;font-size:13px;line-height:1.3;color:var(--faint);margin-bottom:10px}
.h-40p{min-height:40px;display:flex;align-items:flex-end;justify-content:center}
.col.active .step-label{color:var(--red);font-weight:600}
.step{position:relative;z-index:1;width:30px;height:30px;margin:0 auto;border-radius:50%;
  display:grid;place-items:center;background:var(--surface);border:2px solid var(--line-2);
  color:var(--faint);font-size:13px;font-weight:600}
.col.active .step{background:var(--red);border-color:var(--red);color:#fff}
.wizard .col::before{content:"";position:absolute;z-index:0;left:-50%;width:100%;top:65px;height:2px;background:var(--line)}
.wizard .col:first-child::before{display:none}
.wizard .col.active::before{background:var(--red)}

/* ── chips（多選）─────────────────────────────────── */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{position:relative;margin:0;cursor:pointer;user-select:none}
.chip input{position:absolute;opacity:0;width:0;height:0}
.chip span{display:inline-flex;align-items:center;min-height:44px;padding:9px 18px;
  border:1.5px solid var(--line-2);border-radius:var(--pill);font-size:14px;color:#555;background:var(--surface);transition:.15s}
.chip:hover span{border-color:var(--red);color:var(--red)}
.chip input:checked + span{background:var(--red);border-color:var(--red);color:#fff}
.chip input:checked + span::before{content:"✓";font-weight:700;margin-right:6px}
.chip input:focus-visible + span{box-shadow:0 0 0 3px var(--red-50)}

/* ── timeline（進度 / 活動紀錄）───────────────────── */
.tl{list-style:none;margin:0;padding:0}
.tl li{display:flex;gap:12px;padding:12px 0;border-top:1px solid var(--line)}
.tl li:first-child{border-top:0}
.tl .b{width:26px;height:26px;border-radius:50%;flex:none;display:grid;place-items:center;
  font-size:12px;font-weight:600;background:#eceef1;color:var(--muted)}
.tl .b.ok{background:var(--red);color:#fff}
.tl .b.cur{background:#fff;border:2px solid var(--red);color:var(--red)}
.tl p{margin:0;font-size:14px;color:var(--ink-2)}
.tl p b{color:var(--ink)}
.tl img{flex:none}

/* ── upload（設計素材 / 商品主圖）─────────────────── */
.ug{margin-bottom:20px}
.ug:last-child{margin-bottom:0}
.ug-h{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-weight:600}
.ug-h .req{font-size:12px;color:var(--red);font-weight:400}
.drop{display:block;border:1.5px dashed var(--line-2);border-radius:var(--r-lg);padding:18px;text-align:center;
  color:var(--muted);font-size:13.5px;background:var(--bg);cursor:pointer;transition:.15s}
.drop:hover,.drop.over{border-color:var(--red);background:var(--red-50);color:var(--red)}
.files{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}
.files:empty{display:none}
@media(max-width:575px){.files{grid-template-columns:1fr}}
.file{display:flex;align-items:center;gap:10px;padding:8px 11px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface)}
.file .ic{width:32px;height:32px;border-radius:var(--r-sm);flex:none;display:grid;place-items:center;
  font-size:10px;font-weight:700;background:var(--red-50);color:var(--red)}
.file b{font-size:12.5px;font-weight:600;word-break:break-all;display:block;line-height:1.3}
.file small{font-size:11px;color:var(--muted)}
.file.bad .ic{background:var(--danger-50);color:var(--danger)}
.file.bad small{color:var(--danger)}

/* ── key-value（後台詳情）─────────────────────────── */
.kv{display:grid;grid-template-columns:96px 1fr;gap:8px 14px;font-size:14px;margin:0}
.kv dt{color:var(--muted);font-weight:400}
.kv dd{margin:0;color:var(--ink-2)}

/* ── 退回原因框 ───────────────────────────────────── */
.reject-box{background:var(--danger-50);border:1px solid #f3d2d0;border-left:4px solid var(--danger);border-radius:var(--r-lg);padding:14px 16px}
.reject-box b{color:var(--danger)}

/* ── 上線成功打勾 ─────────────────────────────────── */
.tick{width:64px;height:64px;border-radius:50%;border:3px solid var(--red);color:var(--red);
  display:grid;place-items:center;font-size:30px;margin:0 auto 20px}

/* ── misc ─────────────────────────────────────────── */
.img-circle{border-radius:50%;object-fit:cover}
.overdue{color:var(--danger);font-weight:600}
.icon-ok::before{content:"✓"}
.border-top{border-top:1px solid var(--line)}
.prod{position:relative}

/* ── welcome hero ─────────────────────────────────── */
.hero{max-width:30em;margin:7vh auto 0;text-align:center;padding-bottom:4rem}
.hero-eyebrow{font-size:13px;font-weight:600;color:var(--red);letter-spacing:.06em;margin:0 0 16px}
.hero-title{font-size:40px;line-height:1.16;font-weight:800;letter-spacing:-.02em;color:var(--ink);margin:0 0 20px}
.hero-lead{font-size:16px;line-height:1.75;color:var(--muted);margin:0 0 30px}
.hero-lead b{color:var(--ink-2);font-weight:600}
@media(max-width:575px){.hero-title{font-size:30px}}

/* ── footer ───────────────────────────────────────── */
.slim-footer{border-top:1px solid var(--line);text-align:center;padding:18px;margin-top:48px}

/* ── flatpickr 品牌色 ─────────────────────────────── */
.flatpickr-day.selected,.flatpickr-day.selected:hover{background:var(--red);border-color:var(--red)}
.flatpickr-day.today{border-color:var(--red)}
.flatpickr-day:hover{background:var(--red-50)}

@media (prefers-reduced-motion:reduce){*{transition:none!important}}
