:root{
  --bg:#f4f1ea; --paper:#fbf9f4; --card:#ffffff;
  --ink:#16324a; --text:#23282d; --muted:#73777e; --faint:#9a9ea4;
  --line:#e6e1d6; --line2:#efebe1;
  --accent:#c0673a; --accent-s:#f8ece4;
  --gold:#b08436; --red:#c0392b; --green:#2e7d5b;
  --shadow:0 1px 2px rgba(20,40,60,.04),0 10px 30px rgba(20,40,60,.06);
  --display:"Fraunces",Georgia,"Songti SC","Noto Serif CJK SC",serif;
  --mono:"IBM Plex Mono","SF Mono",ui-monospace,monospace;
  --sans:-apple-system,BlinkMacSystemFont,"PingFang SC","Hiragino Sans GB","Segoe UI",system-ui,sans-serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:radial-gradient(120% 80% at 100% 0%, #f7f3ea 0%, var(--bg) 55%) no-repeat;
  min-height:100vh;color:var(--text);font-family:var(--sans);line-height:1.7;font-size:15.5px;-webkit-font-smoothing:antialiased}
.wrap{max-width:1080px;margin:0 auto;padding:0 22px 90px}
.hidden{display:none!important}
a{color:var(--accent)}

/* header */
header{padding:44px 0 6px}
.eyebrow{font-family:var(--mono);font-size:11.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--accent);font-weight:600;margin:0 0 12px}
h1{font-family:var(--display);font-size:40px;line-height:1.08;margin:0 0 10px;color:var(--ink);letter-spacing:-.015em;font-weight:600}
h1 em{font-style:italic;color:var(--accent)}
.sub{font-size:14.5px;color:var(--muted);margin:0;max-width:64ch}

/* input panel */
.inpanel{margin-top:26px;background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:22px 22px 20px}
.inpanel .q{font-family:var(--display);font-size:19px;font-weight:600;color:var(--ink);margin:0 0 4px}
.inpanel .hint{font-size:13px;color:var(--muted);margin:0 0 14px}
.codes{width:100%;min-height:80px;resize:vertical;border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;
  font-family:var(--mono);font-size:16px;letter-spacing:.04em;color:var(--ink);background:var(--paper);line-height:1.7;text-transform:uppercase}
.codes:focus{outline:none;border-color:var(--accent);background:#fff}
.codes::placeholder{color:var(--faint);text-transform:none;letter-spacing:0;font-family:var(--sans)}
.inrow{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:14px}
.field{display:flex;align-items:center;gap:8px}
.field label{font-size:12.5px;color:var(--muted);font-weight:600}
select{font-family:var(--sans);font-size:14px;padding:9px 12px;border:1.5px solid var(--line);border-radius:10px;background:var(--paper);color:var(--ink);cursor:pointer}
.btn{font-family:var(--sans);font-size:15px;font-weight:700;border:none;border-radius:12px;padding:12px 22px;cursor:pointer;transition:transform .12s ease,box-shadow .12s,background .12s}
.btn-primary{background:var(--ink);color:#fff;box-shadow:0 4px 14px rgba(22,50,74,.25)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(22,50,74,.3)}
.btn-primary:disabled{opacity:.55;cursor:wait;transform:none}
.btn-ghost{background:var(--paper);color:var(--ink);border:1px solid var(--line);font-weight:600;font-size:13px;padding:9px 14px;box-shadow:var(--shadow)}
.btn-ghost:hover{background:#fff;transform:translateY(-1px)}
.examples{margin-top:14px;font-size:12.5px;color:var(--faint)}
.examples b{color:var(--muted)}
.exchip{display:inline-block;font-family:var(--mono);font-size:12px;color:var(--accent);background:var(--accent-s);border:1px solid #e6c3ac;
  border-radius:8px;padding:3px 9px;margin:3px 4px 0 0;cursor:pointer}
.exchip:hover{background:#fff}
.inmsg{margin-top:12px;font-size:13px;color:var(--red);font-weight:600;min-height:18px}

/* dashboard */
.dash{display:flex;flex-wrap:wrap;gap:12px;margin:26px 0 6px;align-items:stretch}
.stat{flex:1;min-width:118px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:13px 15px;box-shadow:var(--shadow)}
.stat .n{font-family:var(--display);font-size:28px;font-weight:600;color:var(--ink);line-height:1}
.stat .n small{font-size:13px;color:var(--muted);font-weight:500;margin-left:3px}
.stat .l{font-size:11.5px;color:var(--muted);margin-top:6px}
.stat .days{display:flex;gap:4px;margin-top:8px}
.stat .days span{font-family:var(--mono);font-size:10px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:6px;background:#f0ece2;color:var(--faint)}
.stat .days span.on{background:var(--ink);color:#fff}
.stat.asof .n{font-size:14px;font-family:var(--sans);font-weight:700;padding-top:5px}
.controls{display:flex;gap:8px;align-items:center;margin-left:auto;align-self:center;flex-wrap:wrap}

/* clash banner */
.clashbar{display:none;align-items:flex-start;gap:10px;margin:16px 0 0;background:#fcecea;border:1px solid #f0c4be;color:#8e2a1e;border-radius:12px;padding:11px 15px;font-size:13.5px;font-weight:600;line-height:1.5}
.clashbar.show{display:flex}
.clashbar .dot{width:9px;height:9px;border-radius:50%;background:var(--red);flex:none;box-shadow:0 0 0 4px #f7d6d1;margin-top:6px}
.warnbar{margin:14px 0 0;background:#fdf6e9;border:1px solid #ecd9a8;color:#8a6516;border-radius:12px;padding:10px 14px;font-size:13px;font-weight:600}

/* 智能排课偏好 */
.prefbar{margin:16px 0 0;background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:15px 18px 16px}
.prefhead{font-family:var(--display);font-size:16px;font-weight:600;color:var(--ink);margin-bottom:11px}
.prefhead small{font-family:var(--sans);font-size:11.5px;color:var(--faint);font-weight:400;margin-left:6px}
.prefrow{display:flex;align-items:center;gap:12px;margin-top:9px;flex-wrap:wrap}
.prefkey{font-size:12px;color:var(--muted);font-weight:600;min-width:82px}
.seg{display:inline-flex;gap:6px;flex-wrap:wrap}
.seg button{font-family:var(--sans);font-size:12.5px;font-weight:600;color:var(--muted);background:var(--paper);border:1px solid var(--line);border-radius:9px;padding:6px 12px;cursor:pointer;transition:all .12s ease}
.seg button:hover{border-color:var(--accent);color:var(--ink)}
.seg button.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.seg.days button{min-width:34px;padding:6px 0;text-align:center;font-family:var(--mono)}
.prefact{display:flex;align-items:center;gap:14px;margin-top:14px;flex-wrap:wrap}
.prefact .btn-primary{font-size:14px;padding:10px 18px}
.prefmsg{font-size:12.5px;font-weight:600;line-height:1.5;color:var(--green);flex:1;min-width:180px}

/* layout */
.grid-layout{display:grid;grid-template-columns:1.32fr 1fr;gap:24px;margin-top:22px;align-items:start}
@media(max-width:880px){.grid-layout{grid-template-columns:1fr}.tt{position:static}}
.panel{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}
.panel-h{display:flex;align-items:baseline;gap:10px;padding:15px 18px 12px;border-bottom:1px solid var(--line2)}
.panel-h .t{font-family:var(--display);font-size:17px;font-weight:600;color:var(--ink)}
.panel-h .x{font-family:var(--mono);font-size:10.5px;color:var(--faint);letter-spacing:.05em;margin-left:auto}

/* timetable grid */
@media(min-width:881px){.tt{position:sticky;top:14px}}/* 仅桌面双栏粘性;手机端默认 static,避免课表卡顶 */
.ttgrid{display:grid;padding:10px 14px 14px}
.colhead{font-size:12.5px;font-weight:700;color:var(--ink);text-align:center;padding:4px 0 10px}
.colhead small{display:block;font-family:var(--mono);font-size:9px;color:var(--faint);font-weight:500;letter-spacing:.06em}
.timecol{position:relative}
.timecol .hr{font-family:var(--mono);font-size:10px;color:var(--faint);text-align:right;padding-right:8px;transform:translateY(-6px)}
.day{position:relative;border-left:1px solid var(--line2)}
.day .hr{border-top:1px solid var(--line2)}
.day .hr:first-child{border-top:none}
.blk{position:absolute;left:3px;right:3px;border-radius:8px;padding:3px 6px;overflow:hidden;color:#fff;box-shadow:0 1px 2px rgba(0,0,0,.12);border:1.5px solid transparent}
.blk .c{font-family:var(--mono);font-size:9.5px;font-weight:600;letter-spacing:.02em;line-height:1.2;opacity:.95;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.blk .ty{font-size:10px;font-weight:700;margin-top:0;line-height:1.2}
.blk .tm{font-family:var(--mono);font-size:9px;opacity:.85;margin-top:1px;line-height:1.2}
.blk.tut{background-image:linear-gradient(135deg,rgba(255,255,255,.16) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.16) 50%,rgba(255,255,255,.16) 75%,transparent 75%);background-size:9px 9px}
.blk.clash{border-color:#fff;box-shadow:0 0 0 2px var(--red),0 1px 3px rgba(0,0,0,.2)}

/* unit cards */
.cards{display:flex;flex-direction:column;gap:15px}
.unit{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;border-left:4px solid var(--cc)}
.unit .uh{display:flex;align-items:center;gap:10px;padding:13px 15px 11px}
.unit .code{font-family:var(--mono);font-size:12px;font-weight:600;color:#fff;background:var(--cc);padding:3px 9px;border-radius:7px;letter-spacing:.02em}
.unit .nm{font-size:13.5px;font-weight:700;color:var(--ink);line-height:1.3}
.unit .mode{margin-left:auto;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap}
.mode.campus{color:var(--accent);background:var(--accent-s)}
.mode.online{color:#876fae;background:#efeaf5}
.unit .body{padding:0 15px 14px}
.grp{margin-top:11px}
.grp .lab{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:7px;display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.grp .lab .tag{font-family:var(--sans);font-size:10px;font-weight:700;letter-spacing:0;text-transform:none;padding:1px 7px;border-radius:6px}
.tag.fixed{color:var(--muted);background:#f0ece2}
.tag.pick{color:#fff;background:var(--cc)}
.fixedslot{display:inline-flex;align-items:center;gap:8px;background:var(--cc-s);color:var(--ink);border:1px solid var(--cc-b);border-radius:9px;padding:7px 11px;font-size:13px;font-weight:600}
.fixedslot b{font-family:var(--mono);font-weight:600}
.fixedslot .loc{font-weight:500;color:var(--muted);font-size:11px}
.chips{display:flex;flex-wrap:wrap;gap:6px}
.gday{margin-top:7px}
.gday .gd{font-size:10.5px;color:var(--faint);margin-bottom:4px;font-weight:600}
.chip{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:9px;padding:6px 9px;cursor:pointer;transition:all .12s ease;user-select:none}
.chip:hover{border-color:var(--cc);background:#fff;transform:translateY(-1px)}
.chip.sel{background:var(--cc);border-color:var(--cc);color:#fff;box-shadow:0 2px 6px rgba(0,0,0,.12)}
.seldetail{margin-top:7px;font-size:11.5px;color:var(--muted);line-height:1.55}
.note{background:var(--cc-s);border-radius:10px;padding:9px 12px;font-size:12.5px;color:var(--text);margin-top:8px;line-height:1.55}
.note b{color:var(--ink)}

.legend{display:flex;flex-wrap:wrap;gap:14px;margin:4px 0 10px}
.legend .li{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted)}
.legend .sw{width:22px;height:12px;border-radius:4px;background:var(--ink)}
.legend .sw.t{background-image:linear-gradient(135deg,rgba(255,255,255,.5) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.5) 50%,rgba(255,255,255,.5) 75%,transparent 75%);background-size:7px 7px}

/* loading */
.loading{display:flex;align-items:center;gap:12px;justify-content:center;padding:40px 0;color:var(--muted);font-size:14px}
.spinner{width:22px;height:22px;border:2.5px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* online notes */
.onlinewrap{margin-top:18px;display:flex;flex-direction:column;gap:10px}

/* 悬浮意见箱 */
.fab{position:fixed;right:22px;bottom:22px;z-index:60;display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.fabbtn{display:inline-flex;align-items:center;gap:7px;background:var(--ink);color:#fff;border:none;border-radius:999px;padding:13px 20px;font-family:var(--sans);font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 6px 20px rgba(22,50,74,.28);transition:transform .14s ease,box-shadow .14s}
.fabbtn:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(22,50,74,.34)}
.fabicon{font-size:17px}
.fabpanel{width:330px;max-width:calc(100vw - 36px);background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:0 14px 44px rgba(20,40,60,.20);padding:15px 16px 16px;animation:fabup .18s ease}
@keyframes fabup{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.fabpanel-h{display:flex;align-items:center;justify-content:space-between;font-family:var(--display);font-size:16px;font-weight:600;color:var(--ink)}
.fabclose{background:none;border:none;font-size:23px;line-height:1;color:var(--faint);cursor:pointer;padding:0 2px}
.fabclose:hover{color:var(--ink)}
.fabpanel-sub{font-size:12px;color:var(--muted);margin:5px 0 11px}
.fabpanel textarea{width:100%;min-height:82px;resize:vertical;border:1.5px solid var(--line);border-radius:11px;padding:10px 12px;font-family:var(--sans);font-size:14px;color:var(--ink);background:var(--paper);line-height:1.6}
.fabpanel input{width:100%;margin-top:9px;border:1.5px solid var(--line);border-radius:10px;padding:9px 12px;font-family:var(--sans);font-size:13px;color:var(--ink);background:var(--paper)}
.fabpanel textarea:focus,.fabpanel input:focus{outline:none;border-color:var(--accent);background:#fff}
.fabpanel textarea::placeholder,.fabpanel input::placeholder{color:var(--faint)}
.fabrow{display:flex;align-items:center;gap:12px;margin-top:11px;flex-wrap:wrap}
.fabrow .btn-primary{font-size:14px;padding:9px 20px}
.fbmsg{font-size:12.5px;font-weight:600;color:var(--green);line-height:1.4}
@media(max-width:560px){.fab{right:14px;bottom:14px}.fabbtn{padding:11px 16px;font-size:13.5px}}
@media print{.fab{display:none}}

footer{padding:26px 2px 0;color:var(--muted);font-size:12px;line-height:1.7;margin-top:28px;border-top:1px solid var(--line)}
footer b{color:var(--ink)}
.disc{margin-top:10px;font-size:11.5px;color:var(--faint)}

@media print{body{background:#fff}.controls,.eyebrow,.inpanel{display:none}.panel,.unit,.stat{box-shadow:none}.tt{position:static}}
@media(max-width:560px){
  h1{font-size:30px}.wrap{padding:0 15px 70px}
  .ttgrid{padding:8px 7px 12px}.blk{padding:4px 5px}.blk .ty{font-size:9.5px}.colhead{font-size:11px}
  .inpanel{padding:18px 16px 16px}
}
