/* 夜讀誌 NOCTURNE — Art Nouveau 文藝誌
   Design system. Pure static. © BridgeSeqLab 橋序創研 */

:root{
  --teal-deep:#081c20;
  --teal:#0e2a2e;
  --teal-2:#123a3f;
  --teal-line:#1f5057;
  --gold:#c8a253;
  --gold-bright:#e6cd84;
  --gold-soft:#a8863f;
  --cream:#f5edd9;
  --cream-2:#efe5cb;
  --cream-dim:#e4d8b8;
  --sage:#8aa087;
  --rust:#b4673c;
  --ink:#13282b;
  --muted:#5d6b63;
  --paper:#f7f1e1;

  --serif:"Noto Serif TC","Cormorant Garamond",Georgia,"Songti TC",serif;
  --display:"Cormorant Garamond","Noto Serif TC",Georgia,serif;
  --sans:"Noto Sans TC","Helvetica Neue",Arial,sans-serif;

  --maxw:1140px;
  --shadow:0 18px 46px -24px rgba(8,28,32,.55);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--serif);
  color:var(--ink);
  background:var(--paper);
  line-height:1.85;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}

/* ---------- decorative paper texture ---------- */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(circle at 12% 18%,rgba(200,162,83,.05),transparent 42%),
    radial-gradient(circle at 88% 82%,rgba(138,160,135,.05),transparent 42%);
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:1}

/* ---------- top bar ---------- */
.topbar{background:var(--teal-deep);color:var(--cream);border-bottom:2px solid var(--gold-soft)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;gap:18px}
.brand{display:flex;align-items:center;gap:13px;color:var(--cream)}
.brand svg{width:42px;height:42px;flex:none}
.brand>span{display:flex;flex-direction:column;justify-content:center}
.brand .bt{display:block;font-family:var(--display);font-weight:700;font-size:25px;letter-spacing:.04em;line-height:1;color:var(--gold-bright)}
.brand .bs{display:block;font-family:var(--sans);font-size:10.5px;letter-spacing:.34em;color:var(--cream-dim);text-transform:uppercase;margin-top:4px}

nav.main{display:flex;gap:6px;align-items:center}
nav.main a{
  font-family:var(--sans);font-size:14px;letter-spacing:.06em;color:var(--cream-dim);
  padding:9px 14px;border-radius:2px;transition:.2s;position:relative;
}
nav.main a:hover,nav.main a.active{color:var(--gold-bright)}
nav.main a.active::after{content:"";position:absolute;left:14px;right:14px;bottom:3px;height:1px;background:var(--gold)}

.navtoggle{display:none;background:none;border:1px solid var(--gold-soft);color:var(--gold-bright);
  font-size:20px;width:42px;height:38px;border-radius:3px;cursor:pointer}

/* ---------- hero ---------- */
.hero{background:linear-gradient(170deg,var(--teal) 0%,var(--teal-deep) 100%);color:var(--cream);position:relative;overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding-top:64px;padding-bottom:64px}
.hero .eyebrow{font-family:var(--sans);font-size:12.5px;letter-spacing:.42em;color:var(--gold);text-transform:uppercase;margin-bottom:22px}
.hero h1{font-family:var(--display);font-size:clamp(40px,6vw,72px);line-height:1.04;margin:0 0 8px;font-weight:700;color:var(--cream)}
.hero .h1zh{font-family:var(--serif);font-size:clamp(26px,3.6vw,38px);font-weight:600;color:var(--gold-bright);letter-spacing:.12em;margin:0 0 22px}
.hero p.lead{font-size:18.5px;color:var(--cream-dim);max-width:30em;margin:0 0 30px}
.hero .heroart{position:relative}
.hero .heroart img{border-radius:4px;border:1px solid var(--gold-soft);box-shadow:var(--shadow);width:100%}
.hero .heroart .frame{position:absolute;inset:-12px;border:1px solid rgba(200,162,83,.4);border-radius:6px;pointer-events:none}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-size:14px;letter-spacing:.1em;
  padding:13px 26px;border-radius:2px;cursor:pointer;transition:.22s;border:1px solid var(--gold)}
.btn-gold{background:var(--gold);color:var(--teal-deep);font-weight:600}
.btn-gold:hover{background:var(--gold-bright);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--gold-bright)}
.btn-ghost:hover{background:rgba(200,162,83,.12)}
.btnrow{display:flex;gap:14px;flex-wrap:wrap}

/* ---------- section scaffolding ---------- */
section{padding:74px 0;position:relative}
.sec-head{text-align:center;max-width:42em;margin:0 auto 48px}
.sec-kicker{font-family:var(--sans);font-size:12px;letter-spacing:.4em;color:var(--gold-soft);text-transform:uppercase;margin-bottom:14px}
.sec-head h2{font-family:var(--display);font-size:clamp(30px,4.4vw,46px);margin:0 0 8px;font-weight:700;color:var(--ink)}
.sec-head .h2zh{font-family:var(--serif);font-size:20px;color:var(--gold-soft);letter-spacing:.18em;font-weight:600}
.sec-head p{color:var(--muted);font-size:16.5px}

.tinted{background:var(--teal);color:var(--cream)}
.tinted .sec-head h2{color:var(--cream)}
.tinted .sec-head p{color:var(--cream-dim)}
.tinted .sec-kicker{color:var(--gold)}

/* ---------- ornamental divider ---------- */
.divider{display:flex;align-items:center;justify-content:center;gap:18px;margin:0 auto;color:var(--gold)}
.divider svg{width:240px;height:26px;max-width:62vw}

/* ---------- article cards ---------- */
.grid{display:grid;gap:30px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--paper);border:1px solid var(--cream-dim);border-radius:5px;overflow:hidden;
  display:flex;flex-direction:column;transition:.25s;box-shadow:0 10px 30px -22px rgba(8,28,32,.5)}
.card:hover{transform:translateY(-5px);border-color:var(--gold);box-shadow:0 22px 42px -26px rgba(8,28,32,.6)}
.card .thumb{aspect-ratio:16/10;overflow:hidden;background:var(--teal);border-bottom:1px solid var(--cream-dim)}
.card .thumb img{width:100%;height:100%;object-fit:cover;transition:.5s}
.card:hover .thumb img{transform:scale(1.05)}
.card .body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.cat{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--rust);margin-bottom:11px}
.card h3{font-family:var(--display);font-size:25px;line-height:1.25;margin:0 0 10px;font-weight:700}
.card h3 .zh{display:block;font-family:var(--serif);font-size:19px;color:var(--ink);font-weight:600;letter-spacing:.04em}
.card p{color:var(--muted);font-size:15px;margin:0 0 16px;flex:1}
.card .meta{font-family:var(--sans);font-size:12.5px;color:var(--gold-soft);letter-spacing:.04em;display:flex;gap:10px;align-items:center}
.readmore{font-family:var(--sans);font-size:13px;letter-spacing:.08em;color:var(--gold-soft);margin-top:14px;display:inline-flex;gap:7px;align-items:center}
.card:hover .readmore{color:var(--rust)}

/* feature card on tinted bg */
.tinted .card{background:rgba(245,237,217,.04);border-color:var(--teal-line)}
.tinted .card h3 .zh,.tinted .card h3{color:var(--cream)}
.tinted .card p{color:var(--cream-dim)}

/* ---------- column tiles ---------- */
.cols{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.coltile{border:1px solid var(--cream-dim);border-radius:5px;padding:34px 28px;background:var(--paper);text-align:center;transition:.25s}
.coltile:hover{border-color:var(--gold);transform:translateY(-4px)}
.coltile .ic{width:62px;height:62px;margin:0 auto 18px;color:var(--gold-soft)}
.coltile h3{font-family:var(--display);font-size:24px;margin:0 0 4px;font-weight:700}
.coltile .zh{font-family:var(--serif);font-size:16px;color:var(--gold-soft);letter-spacing:.14em;margin-bottom:12px}
.coltile p{color:var(--muted);font-size:14.5px;margin:0}

/* ---------- article body ---------- */
.article-head{background:linear-gradient(170deg,var(--teal) 0%,var(--teal-deep) 100%);color:var(--cream);padding:60px 0 54px}
.breadcrumb{font-family:var(--sans);font-size:12.5px;letter-spacing:.06em;color:var(--gold-soft);margin-bottom:26px}
.breadcrumb a:hover{color:var(--gold-bright)}
.breadcrumb span{margin:0 8px;opacity:.6}
.article-head .cat{color:var(--gold)}
.article-head h1{font-family:var(--display);font-size:clamp(34px,5vw,56px);line-height:1.1;margin:0 0 12px;color:var(--cream);font-weight:700;max-width:18em}
.article-head .sub{font-size:19px;color:var(--cream-dim);max-width:34em;margin:0 0 22px}
.article-head .by{font-family:var(--sans);font-size:13px;letter-spacing:.05em;color:var(--gold-soft);display:flex;gap:12px;flex-wrap:wrap}
.article-hero{margin:0 auto;max-width:var(--maxw);padding:0 28px}
.article-hero img{width:100%;border-radius:5px;border:1px solid var(--cream-dim);margin-top:-40px;box-shadow:var(--shadow);position:relative;z-index:2;aspect-ratio:16/7;object-fit:cover}

.prose{max-width:720px;margin:0 auto;padding:54px 28px 30px}
.prose .lede{font-size:21px;line-height:1.7;color:var(--ink);font-weight:600;margin:0 0 30px}
.prose p{margin:0 0 22px;color:#26393a}
.prose h2{font-family:var(--display);font-size:32px;margin:46px 0 8px;font-weight:700;color:var(--ink)}
.prose h2 .zh{display:block;font-family:var(--serif);font-size:21px;color:var(--gold-soft);font-weight:600;letter-spacing:.06em;margin-top:2px}
.prose h3{font-family:var(--serif);font-size:21px;margin:34px 0 6px;color:var(--teal-2);font-weight:600}
.prose blockquote{margin:30px 0;padding:6px 0 6px 26px;border-left:3px solid var(--gold);
  font-family:var(--display);font-size:26px;line-height:1.5;color:var(--teal-2);font-style:italic}
.prose blockquote .zh{font-family:var(--serif);font-size:20px;font-style:normal;color:var(--muted);display:block;margin-top:8px}
.prose figure{margin:34px 0}
.prose figure img{border-radius:5px;border:1px solid var(--cream-dim)}
.prose figcaption{font-family:var(--sans);font-size:12.5px;color:var(--muted);text-align:center;margin-top:10px;letter-spacing:.03em}
.prose ul{padding-left:22px;margin:0 0 22px}
.prose li{margin:0 0 9px;color:#26393a}
.prose a.inline{color:var(--rust);border-bottom:1px solid rgba(180,103,60,.4)}
.prose a.inline:hover{border-color:var(--rust)}
.dropcap::first-letter{font-family:var(--display);font-size:64px;float:left;line-height:.78;padding:6px 12px 0 0;color:var(--gold-soft);font-weight:700}

.endmark{display:flex;justify-content:center;margin:40px 0 10px;color:var(--gold)}

/* related */
.related{border-top:1px solid var(--cream-dim);background:var(--cream-2)}

/* ---------- gallery / illustration ---------- */
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:22px}
.plate{border:1px solid var(--cream-dim);border-radius:5px;overflow:hidden;background:var(--paper);position:relative}
.plate img,.plate svg{width:100%;display:block}
.plate .cap{padding:14px 18px;font-family:var(--sans);font-size:12.5px;color:var(--muted);letter-spacing:.04em;border-top:1px solid var(--cream-dim)}
.plate .cap b{font-family:var(--serif);color:var(--ink);font-weight:600;font-size:14px;display:block;margin-bottom:2px}
.svgplate{background:var(--teal);color:var(--gold)}

/* ---------- subscribe / contact ---------- */
.subcard{background:var(--teal);color:var(--cream);border-radius:8px;padding:54px 48px;text-align:center;box-shadow:var(--shadow);border:1px solid var(--teal-line)}
.subcard h2{font-family:var(--display);font-size:38px;margin:0 0 8px;color:var(--cream);font-weight:700}
.subcard .zh{font-family:var(--serif);color:var(--gold-bright);letter-spacing:.16em;margin-bottom:14px}
.subcard p{color:var(--cream-dim);max-width:34em;margin:0 auto 26px}
.subform{display:flex;gap:12px;max-width:480px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.subform input{flex:1;min-width:220px;background:rgba(245,237,217,.07);border:1px solid var(--teal-line);color:var(--cream);
  padding:13px 16px;border-radius:3px;font-family:var(--serif);font-size:15px}
.subform input::placeholder{color:#9fb0a8}
.subform input:focus{outline:none;border-color:var(--gold)}

.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:660px;margin:0 auto}
.field{display:flex;flex-direction:column;gap:7px}
.field.full{grid-column:1/-1}
.field label{font-family:var(--sans);font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-soft)}
.field input,.field textarea,.field select{background:var(--paper);border:1px solid var(--cream-dim);color:var(--ink);
  padding:12px 14px;border-radius:3px;font-family:var(--serif);font-size:15.5px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--gold)}
.field textarea{min-height:130px;resize:vertical}

.infoblocks{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:8px}
.infoblock{border:1px solid var(--cream-dim);border-radius:5px;padding:26px;background:var(--paper)}
.infoblock .ic{width:38px;height:38px;color:var(--gold-soft);margin-bottom:12px}
.infoblock h3{font-family:var(--serif);font-size:18px;margin:0 0 4px;font-weight:600}
.infoblock p{color:var(--muted);font-size:14.5px;margin:0}

/* faq */
.faq{max-width:760px;margin:0 auto}
.faq details{border:1px solid var(--cream-dim);border-radius:5px;margin-bottom:14px;background:var(--paper);padding:0 22px}
.faq summary{cursor:pointer;list-style:none;padding:20px 0;font-family:var(--serif);font-size:18px;font-weight:600;
  display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{color:var(--gold-soft);font-size:24px;transition:.2s;flex:none}
.faq details[open] summary .pm{transform:rotate(45deg)}
.faq details p{color:var(--muted);font-size:15px;margin:0 0 20px;padding-top:2px}

/* ---------- about ---------- */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.about-split img{border-radius:6px;border:1px solid var(--cream-dim);box-shadow:var(--shadow)}
.values{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:34px}
.value{border-top:2px solid var(--gold);padding-top:14px}
.value h3{font-family:var(--serif);font-size:18px;margin:0 0 5px;font-weight:600}
.value p{color:var(--muted);font-size:14.5px;margin:0}
.stats{display:flex;gap:48px;flex-wrap:wrap;justify-content:center;margin-top:10px}
.stat{text-align:center}
.stat b{font-family:var(--display);font-size:46px;color:var(--gold);display:block;line-height:1;font-weight:700}
.stat span{font-family:var(--sans);font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

/* ---------- footer ---------- */
footer.site{background:var(--teal-deep);color:var(--cream-dim);padding:60px 0 30px;border-top:2px solid var(--gold-soft)}
footer.site .cols-f{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px}
footer.site .brand .bt{font-size:22px}
footer.site .fdesc{font-size:14.5px;color:#9fb0a8;max-width:26em;margin:16px 0 0}
footer.site h4{font-family:var(--sans);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin:0 0 16px}
footer.site ul{list-style:none;padding:0;margin:0}
footer.site li{margin-bottom:10px}
footer.site a{font-size:14.5px;color:var(--cream-dim)}
footer.site a:hover{color:var(--gold-bright)}
.footrow{border-top:1px solid var(--teal-line);padding-top:22px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
  font-family:var(--sans);font-size:12.5px;color:#8295a8;letter-spacing:.03em}
.footrow a{color:#8295a8}
.footrow a:hover{color:var(--gold-bright)}

/* ---------- misc ---------- */
.notfound{min-height:62vh;display:flex;align-items:center;justify-content:center;text-align:center;
  background:linear-gradient(170deg,var(--teal) 0%,var(--teal-deep) 100%);color:var(--cream)}
.notfound .big{font-family:var(--display);font-size:clamp(90px,18vw,180px);color:var(--gold);line-height:1;font-weight:700}
.notfound h1{font-family:var(--serif);font-size:28px;color:var(--cream);margin:6px 0 14px}
.notfound p{color:var(--cream-dim);margin:0 0 26px}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .hero .wrap{grid-template-columns:1fr;gap:36px;text-align:center}
  .hero p.lead{margin-left:auto;margin-right:auto}
  .hero .btnrow{justify-content:center}
  .hero .heroart{max-width:420px;margin:0 auto}
  .about-split{grid-template-columns:1fr;gap:32px}
  .about-split .imgwrap{order:-1}
  .gallery{grid-template-columns:repeat(6,1fr)}
}
@media(max-width:760px){
  nav.main{position:absolute;top:74px;left:0;right:0;background:var(--teal-deep);flex-direction:column;gap:0;
    padding:8px 0;border-bottom:2px solid var(--gold-soft);display:none;z-index:40}
  nav.main.open{display:flex}
  nav.main a{padding:13px 28px;width:100%}
  .navtoggle{display:block}
  .grid-3,.grid-2,.cols,.infoblocks,.values{grid-template-columns:1fr}
  .formgrid{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}
  footer.site .cols-f{grid-template-columns:1fr 1fr;gap:28px}
  .subcard{padding:38px 24px}
  section{padding:54px 0}
  .stats{gap:30px}
}
@media(max-width:440px){
  footer.site .cols-f{grid-template-columns:1fr}
  body{font-size:16.5px}
}
