/* 私立國中查詢 · © 2025 */

/* Accessibility: screen-reader only */
.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}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ivory:#f7f5f1;
  --paper:#efece6;
  --white:#ffffff;
  --line:#dedad2;
  --line2:#c8c4ba;
  --ink:#18170e;
  --ink2:#3a3830;
  --ink3:#5e5c54;
  --ink4:#8a877e;
  --warm:#7a6e5e;
  --warm-bg:#f0ebe3;
  --up:#3d6b4e;
  --up-bg:#e6f0eb;
  --down:#7a3d3d;
  --down-bg:#f0e6e6;
  --flat-bg:#eceae5;
  --r:8px;
  --r-sm:5px;
  --font:-apple-system,"Hiragino Sans","PingFang TC","Noto Sans TC","Helvetica Neue",sans-serif;
  --font-serif:"Hiragino Mincho ProN","Noto Serif TC","Georgia",serif;
}
html{scroll-behavior:smooth}
body{background:var(--ivory);color:var(--ink);font-family:var(--font);
  line-height:1.6;-webkit-font-smoothing:antialiased;font-size:18px}

/* NAV */
nav{position:sticky;top:0;z-index:100;background:rgba(247,245,241,.96);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:1320px;margin:0 auto;padding:0 40px;
  display:flex;align-items:center;justify-content:space-between;height:60px}
.nav-brand{display:flex;align-items:center;gap:10px}
.nav-dot{width:7px;height:7px;border-radius:50%;background:var(--warm)}
.nav-logo{font-family:var(--font-serif);font-size:18px;color:var(--ink);letter-spacing:.04em;text-decoration:none}
.nav-count{font-size:15px;color:var(--ink3);letter-spacing:.06em}

/* HERO */
.hero{max-width:1320px;margin:0 auto;padding:72px 40px 60px}
.hero-label{font-size:13px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--warm);margin-bottom:16px;font-weight:600}
.hero-h1{font-family:var(--font-serif);font-size:clamp(32px,4.5vw,52px);
  font-weight:400;letter-spacing:.04em;line-height:1.4;
  color:var(--ink);margin-bottom:18px}
.hero-sub{font-size:17px;color:var(--ink2);max-width:540px;
  line-height:1.9;letter-spacing:.04em;margin-bottom:52px}
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.kpi-card{background:var(--white);border:1px solid var(--line);
  border-radius:var(--r);padding:24px 26px}
.kpi-num{font-family:var(--font-serif);font-size:clamp(30px,3.2vw,44px);
  font-weight:400;letter-spacing:-.01em;color:var(--ink);line-height:1}
.kpi-num b{color:var(--warm);font-weight:400}
.kpi-label{font-size:14px;color:var(--ink3);margin-top:8px;letter-spacing:.04em;font-weight:500}
.kpi-sub{font-size:13px;color:var(--ink4);margin-top:3px}

/* TOOLBAR */
.toolbar{position:sticky;top:60px;z-index:90;background:rgba(247,245,241,.97);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.toolbar-inner{max-width:1320px;margin:0 auto;padding:0 40px;
  display:flex;align-items:center;gap:0;min-height:54px;flex-wrap:wrap}
.search-wrap{position:relative;margin-right:28px;padding:14px 0;flex-shrink:0}
/* sort-wrap: flex row so result-n sits beside the select */
.sort-wrap{margin-left:auto;display:flex;align-items:center;gap:0}
.search-wrap input{
  background:transparent;border:none;border-bottom:1px solid var(--line2);
  color:var(--ink);padding:6px 0 6px 28px;font-size:15px;width:200px;
  outline:none;font-family:var(--font);letter-spacing:.04em;
  transition:border-color .35s;caret-color:var(--warm)}
.search-wrap input:focus{border-color:var(--warm)}
.search-wrap input::placeholder{color:var(--ink4)}
.search-icon{position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:15px;height:15px;color:var(--ink4);pointer-events:none}
.filter-group{display:flex;align-items:center;gap:0;
  border-right:1px solid var(--line);padding-right:20px;margin-right:20px}
.filter-group:last-of-type{border-right:none}
.fchip{padding:8px 14px;font-family:var(--font);font-size:14px;font-weight:500;
  letter-spacing:.04em;background:transparent;border:none;color:var(--ink3);
  cursor:pointer;transition:color .3s;position:relative;white-space:nowrap}
.fchip::after{content:'';position:absolute;bottom:-1px;left:14px;right:14px;
  height:2px;background:var(--warm);transform:scaleX(0);
  transform-origin:left;transition:transform .35s cubic-bezier(.4,0,.2,1)}
.fchip:hover{color:var(--ink2)}
.fchip.active{color:var(--ink)}
.fchip.active::after{transform:scaleX(1)}
.sort-sel{background:transparent;border:none;color:var(--ink2);
  font-size:14px;font-family:var(--font);font-weight:500;
  letter-spacing:.04em;outline:none;cursor:pointer;padding:14px 0}
.result-n{font-size:14px;color:var(--ink3);margin-left:24px;white-space:nowrap;font-weight:500}
.result-n strong{color:var(--ink);font-weight:700}

/* 手機版下拉篩選（桌機不顯示） */
.mob-filters{display:none}

/* GRID */
.grid-wrap{max-width:1320px;margin:0 auto;padding:32px 40px 80px}
#grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}

/* CARD */
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);
  padding:26px 24px 22px;cursor:pointer;
  display:flex;flex-direction:column;
  transition:box-shadow .4s,border-color .35s,transform .4s;
  opacity:0;transform:translateY(8px);
  user-select:none;-webkit-user-select:none}
.card.show{opacity:1;transform:none;
  transition:opacity .6s cubic-bezier(.4,0,.2,1),
    transform .6s cubic-bezier(.4,0,.2,1),
    box-shadow .3s,border-color .3s}
.card:hover{box-shadow:0 4px 20px rgba(24,23,14,.08);
  border-color:var(--line2);transform:translateY(-2px)}
.card.hidden{display:none}

.card-loc{font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink4);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.card-loc-sep{width:14px;height:1px;background:var(--line2)}

.card-name{font-family:var(--font-serif);font-size:clamp(20px,1.8vw,24px);
  font-weight:400;letter-spacing:.04em;line-height:1.5;
  color:var(--ink);margin-bottom:22px}
.card-name small{display:block;font-size:12px;letter-spacing:.12em;
  color:var(--warm);font-family:var(--font);margin-bottom:5px;font-weight:600}

.card-nums{display:grid;grid-template-columns:repeat(3,1fr);
  background:var(--ivory);border-radius:var(--r-sm);
  padding:14px 12px;gap:4px;margin-bottom:18px}
.cn-item{text-align:center}
.cn-v{font-family:var(--font-serif);font-size:26px;font-weight:400;
  letter-spacing:-.01em;color:var(--ink)}
.cn-k{font-size:12px;color:var(--ink3);margin-top:4px;letter-spacing:.08em;font-weight:500}

.spark-area{margin-bottom:14px;opacity:.9}
.spark-timeline{display:flex;justify-content:space-between;
  font-size:11px;color:var(--ink4);margin-bottom:4px;
  letter-spacing:.06em;font-weight:500}

.card-trend{margin-bottom:16px}
.tbadge{font-size:13px;font-weight:600;padding:5px 14px;border-radius:100px;white-space:nowrap;
  letter-spacing:.04em}
.tbadge.up{background:var(--up-bg);color:var(--up)}
.tbadge.down{background:var(--down-bg);color:var(--down)}
.tbadge.flat{background:var(--flat-bg);color:var(--ink3)}

.card-foot{display:flex;justify-content:space-between;align-items:center;
  padding-top:14px;border-top:1px solid var(--line);margin-top:auto}
.card-link{font-size:13px;color:var(--warm);text-decoration:none;
  font-weight:600;letter-spacing:.04em}
.card-link:hover{text-decoration:underline;text-underline-offset:3px}
.no-web{font-size:13px;color:var(--ink4);letter-spacing:.04em}
.detail-btn{font-size:13px;color:var(--ink2);background:var(--ivory);
  border:1px solid var(--line);border-radius:var(--r-sm);
  padding:6px 13px;cursor:pointer;font-family:var(--font);
  font-weight:600;letter-spacing:.04em;
  transition:background .25s,border-color .25s,color .25s}
.detail-btn:hover{background:var(--white);border-color:var(--line2);color:var(--ink)}

/* CARD APPEAR */
.card.show:hover{transform:translateY(-2px)}

/* EMPTY */
.empty{grid-column:1/-1;padding:100px 20px;text-align:center;
  font-size:14px;color:var(--ink3);letter-spacing:.12em}
.empty.hidden{display:none}

/* MODAL */
#overlay{position:fixed;inset:0;z-index:500;display:none;
  align-items:flex-end;justify-content:center}
#overlay.open{display:flex}
#ov-bg{position:absolute;inset:0;background:rgba(24,23,14,.35);
  opacity:0;transition:opacity .6s}
#overlay.open #ov-bg{opacity:1}
#modal-panel{position:relative;z-index:1;width:min(600px,100vw);
  height:100vh;background:var(--white);overflow-y:auto;
  transform:translateX(100%);
  transition:transform .65s cubic-bezier(.16,1,.3,1)}
@media(min-width:640px){
  #overlay{align-items:center;justify-content:flex-end}
}
#overlay.open #modal-panel{transform:translateX(0)}
.mp-inner{padding:min(7vw,64px) min(5vw,44px) 48px}
.mp-close{position:absolute;top:16px;right:16px;
  width:36px;height:36px;background:var(--ivory);
  border:1px solid var(--line);border-radius:50%;
  color:var(--ink2);font-size:14px;cursor:pointer;
  z-index:20;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;transition:all .25s}
.mp-close:hover{background:var(--white);border-color:var(--line2);color:var(--ink)}
.mp-region{font-size:13px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--warm);margin-bottom:12px;font-weight:600}
.mp-name{font-family:var(--font-serif);font-size:clamp(22px,3vw,32px);
  font-weight:400;letter-spacing:.04em;line-height:1.35;
  color:var(--ink);margin-bottom:10px}
.mp-sub{font-size:15px;color:var(--ink3);margin-bottom:40px;
  letter-spacing:.06em;font-weight:500}
.mp-stats{display:grid;grid-template-columns:repeat(3,1fr);
  border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;margin-bottom:36px}
.mp-stat{padding:20px 16px;background:var(--ivory)}
.mp-stat:not(:last-child){border-right:1px solid var(--line)}
.mp-stat .v{font-family:var(--font-serif);font-size:32px;
  font-weight:400;letter-spacing:-.01em;color:var(--ink)}
.mp-stat .k{font-size:12px;color:var(--ink3);margin-top:5px;
  letter-spacing:.1em;text-transform:uppercase;font-weight:600}
.mp-divider{height:1px;background:var(--line);margin:28px 0}
.mp-stitle{font-size:13px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink3);margin-bottom:16px;font-weight:700}
.mp-rows{display:flex;flex-direction:column;gap:14px;margin-bottom:24px}
.mp-row{display:flex;gap:16px;line-height:1.7;letter-spacing:.04em}
.mp-key{font-size:12px;font-weight:600;letter-spacing:.08em;color:var(--ink4);
  min-width:64px;padding-top:2px;text-transform:uppercase;flex-shrink:0}
.mp-val{font-size:15px;color:var(--ink2)}
.mp-val a{color:var(--warm);text-decoration:none;font-weight:600}
.mp-val a:hover{text-decoration:underline}

/* ── MODAL TABS ─────────────────────────────── */
.mp-tabs{display:flex;gap:0;border-bottom:2px solid var(--line);margin-bottom:28px}
.mp-tab{background:transparent;border:none;cursor:pointer;
  font-family:var(--font);font-size:15px;font-weight:500;color:var(--ink3);
  padding:10px 20px 12px;position:relative;transition:color .25s;letter-spacing:.04em}
.mp-tab::after{content:'';position:absolute;bottom:-2px;left:0;right:0;
  height:2px;background:var(--warm);transform:scaleX(0);
  transform-origin:left;transition:transform .3s cubic-bezier(.4,0,.2,1)}
.mp-tab.active{color:var(--ink)}
.mp-tab.active::after{transform:scaleX(1)}
.mp-tab-content.hidden{display:none}

/* ── ADMISSION RESULTS ──────────────────────── */
.adm-kpi{display:grid;grid-template-columns:repeat(3,1fr);
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:32px}
.adm-k{padding:18px 16px;background:var(--ivory)}
.adm-k:not(:last-child){border-right:1px solid var(--line)}
.adm-n{font-family:var(--font-serif);font-size:28px;font-weight:400;color:var(--ink);line-height:1}
.adm-n span{font-family:var(--sans);font-size:14px;font-weight:500;color:var(--warm);margin-left:2px}
.adm-l{font-size:12px;color:var(--ink3);margin-top:6px;font-weight:600;letter-spacing:.06em}
.adm-s{font-size:11px;color:var(--ink4);margin-top:3px}
.adm-group-label{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--warm);margin:20px 0 10px;padding-top:20px;border-top:1px solid var(--line)}
.adm-group-label:first-of-type{border-top:none;margin-top:0;padding-top:0}
.adm-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.adm-bar-name{font-size:13px;color:var(--ink2);min-width:200px;flex-shrink:0}
.adm-bar-track{flex:1;height:7px;background:var(--paper);border-radius:4px;overflow:hidden}
.adm-bar-fill{height:100%;border-radius:4px;background:#4a7c59;
  animation:barIn .7s cubic-bezier(.4,0,.2,1) both}
@keyframes barIn{from{width:0!important}to{}}
.adm-bar-n{font-size:13px;font-weight:600;color:var(--ink);min-width:28px;
  text-align:right;font-variant-numeric:tabular-nums}
.adm-extra-row{display:flex;justify-content:space-between;align-items:center;
  padding:7px 0;border-bottom:1px solid var(--line);font-size:14px}
.adm-extra-row:last-child{border-bottom:none}
.adm-extra-label{color:var(--ink2)}
.adm-extra-n{font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}
.adm-note{font-size:12px;color:var(--ink4);margin-top:28px;padding-top:16px;
  border-top:1px solid var(--line);line-height:1.8}
.exam-quote{font-family:var(--font-serif);font-size:18px;color:var(--ink2);
  line-height:1.6;padding:20px 24px;background:var(--paper);
  border-left:3px solid var(--warm);border-radius:0 4px 4px 0;margin:24px 0}
.hist-tbl{width:100%;border-collapse:collapse;table-layout:fixed}
.hist-tbl th{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink3);text-align:right;padding:8px 0;border-bottom:2px solid var(--line)}
.hist-tbl th:first-child{text-align:left;width:80px}
.hist-tbl td{font-size:14px;color:var(--ink2);text-align:right;
  padding:9px 0;border-bottom:1px solid var(--line);
  font-variant-numeric:tabular-nums;letter-spacing:.02em}
.hist-tbl td:first-child{color:var(--ink);text-align:left;font-weight:600}
.hist-tbl tr:last-child td{border-bottom:none}
.hist-tbl tbody tr:first-child td{color:var(--ink);font-weight:700;background:var(--paper)}
.mp-stitle-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:20px}
.mp-stitle-row .mp-stitle{margin-bottom:0}
.trend-extra{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));
  border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;margin-top:20px}
.te-box{background:var(--ivory);padding:16px 14px}
.te-box:not(:last-child){border-right:1px solid var(--line)}
.te-box .v{font-size:15px;font-weight:600;letter-spacing:.04em;color:var(--ink)}
.te-box .k{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink3);margin-top:4px}

/* FOOTER */
footer{border-top:1px solid var(--line);background:var(--white)}
.footer-inner{max-width:1320px;margin:0 auto;padding:28px 40px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
footer p{font-size:13px;color:var(--ink3);letter-spacing:.04em;font-weight:500}
.footer-copy{width:100%;font-size:11px!important;color:var(--ink3)!important;letter-spacing:.02em;line-height:1.7;margin-top:4px;opacity:.75}

@media(max-width:700px){
  /* ── 基礎間距 ──────────────────────────── */
  .nav-inner{padding-left:18px;padding-right:18px}
  .hero{padding:40px 18px 28px}
  .hero-sub{margin-bottom:28px}
  .grid-wrap{padding:14px 18px 60px}
  .footer-inner{padding-left:18px;padding-right:18px}

  /* ── KPI cards ─────────────────────────── */
  .kpi-row{grid-template-columns:repeat(2,1fr);gap:10px}
  .kpi-card{padding:18px 16px}

  /* ── Grid ──────────────────────────────── */
  #grid{grid-template-columns:1fr;gap:12px}

  /* ── Toolbar ───────────────────────────── */
  .toolbar-inner{
    padding:0 18px;
    flex-direction:column;
    align-items:stretch;
    min-height:unset;
    gap:0
  }

  /* Search: full-width strip */
  .search-wrap{
    margin-right:0;
    padding:8px 0;
    border-bottom:1px solid var(--line);
    flex-shrink:unset
  }
  .search-wrap input{width:100%;font-size:16px}

  /* 桌機 chip 全部隱藏，改用 mob-filters */
  .filter-group{display:none}

  /* 手機版篩選下拉列 */
  .mob-filters{
    display:flex;
    gap:8px;
    padding:8px 0;
    border-bottom:1px solid var(--line)
  }
  .mob-sel{
    flex:1;
    background:var(--ivory);
    border:1px solid var(--line2);
    border-radius:var(--r-sm);
    color:var(--ink2);
    font-size:16px;
    font-family:var(--font);
    font-weight:500;
    padding:9px 10px;
    outline:none;
    cursor:pointer;
    appearance:auto;
    min-width:0
  }
  .mob-sel:focus{border-color:var(--warm)}
  .mob-sel option{font-size:16px;font-family:var(--font)}

  /* Sort + result: single compact row */
  .sort-wrap{
    margin-left:0;
    padding:6px 0 8px;
    border-top:none;
    display:flex;
    align-items:center;
    justify-content:space-between;
    width:100%
  }
  .sort-sel{font-size:13px}
  .result-n{
    margin-left:0;
    padding:0;
    font-size:13px
  }

  /* ── Modal ─────────────────────────────── */
  .mp-inner{padding:28px 18px 40px}

  /* ── Admission bars ────────────────────── */
  .adm-bar-name{min-width:140px;font-size:12px}
  .adm-kpi{grid-template-columns:repeat(3,1fr)}
  .adm-n{font-size:22px}
}
