/* ============================================================
   獾拾 HappyHour · infohappyhour.com
   v3 — warm-ivory editorial, deep spruce + antique brass.
   Chinese: Noto Serif SC (subset, variable weight).
   Latin / numerals: Cormorant Garamond + Jost (labels).
   ============================================================ */

:root{
  --paper:#F3EEE3;
  --paper-2:#EAE2D1;
  --card:#FCFAF3;
  --card-2:#F6F0E4;

  --ink:#1B1D18;
  --ink-soft:#54564B;
  --ink-faint:#8C8979;

  --pine:#15302A;
  --pine-2:#1D3B33;
  --pine-line:rgba(241,234,216,.13);
  --cream:#F1EAD7;
  --cream-soft:#A8A18B;

  --brass:#9A742F;
  --brass-bright:#B68A3F;
  --brass-on-dark:#CFA35A;

  --line:rgba(27,29,24,.12);
  --line-soft:rgba(27,29,24,.06);

  --maxw:1240px;
  --gut:56px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--paper);color:var(--ink);
  font-family:"Noto Serif SC","Songti SC","STSong","SimSun",serif;
  font-size:17px;line-height:1.86;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--pine);color:var(--cream)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
.serif{font-family:"Noto Serif SC","Songti SC","STSong","SimSun",serif}
.latin{font-family:"Cormorant Garamond",Georgia,serif}

/* display type — light, high-contrast for elegance */
h1,h2,h3,h4{color:var(--pine);font-feature-settings:"palt" 1}
h1{font-weight:450;line-height:1.14;letter-spacing:.01em}
h2{font-weight:450;line-height:1.24;letter-spacing:.008em}
h3{font-weight:600;letter-spacing:.004em}

/* ---- hero eyebrow ---- */
.eyebrow{
  display:inline-flex;align-items:center;gap:15px;
  font-family:"PingFang SC","Hiragino Sans GB","Noto Sans CJK SC",sans-serif;
  font-size:14px;font-weight:600;letter-spacing:.1em;color:var(--brass);
}
.eyebrow::before{content:"";width:40px;height:1.5px;background:var(--brass);opacity:.9}

/* ---- chapter label (sections) — numbered, with presence ---- */
.chapter{display:inline-flex;align-items:baseline;gap:16px}
.chapter b{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-weight:500;font-size:30px;line-height:1;color:var(--brass);
}
.chapter em{
  font-family:"PingFang SC","Hiragino Sans GB",sans-serif;font-style:normal;
  font-size:16px;font-weight:600;letter-spacing:.05em;color:var(--pine);
}
.chapter--dark b{color:var(--brass-on-dark)}
.chapter--dark em{color:var(--cream)}

/* small caps brass label */
.label{
  display:inline-block;font-family:"PingFang SC","Hiragino Sans GB",sans-serif;
  font-size:12.5px;font-weight:600;letter-spacing:.14em;color:var(--brass);
}
.index{font-family:"Cormorant Garamond",Georgia,serif;font-size:19px;letter-spacing:.18em;color:var(--brass)}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(243,238,227,.84);
  backdrop-filter:saturate(150%) blur(16px);-webkit-backdrop-filter:saturate(150%) blur(16px);
  border-bottom:1px solid var(--line-soft);
}
.nav__inner{max-width:var(--maxw);margin:0 auto;padding:18px var(--gut);display:flex;align-items:center;justify-content:space-between;gap:28px}
.brand{display:flex;align-items:center;gap:13px;min-width:max-content}
.brand img{width:40px;height:40px;object-fit:contain}
.brand__text{display:flex;flex-direction:column;gap:4px}
.brand__name{font-family:"Noto Serif SC",serif;font-weight:600;font-size:18.5px;line-height:1;color:var(--pine)}
.brand__name i{font-family:"Cormorant Garamond",Georgia,serif;font-style:normal;font-weight:600;font-size:19.5px;margin-left:6px;letter-spacing:.01em}
.brand__sub{font-family:"PingFang SC","Hiragino Sans GB",sans-serif;font-size:10.5px;line-height:1;letter-spacing:.22em;color:var(--ink-faint)}
.nav__menu{display:flex;align-items:center;gap:42px}
.nav__menu a{
  position:relative;padding:6px 0;
  font-family:"PingFang SC","Hiragino Sans GB","Noto Sans CJK SC",sans-serif;
  font-size:15px;line-height:1;letter-spacing:.03em;color:var(--ink-soft);transition:color .25s var(--ease);
}
.nav__menu a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1.5px;background:var(--brass);transition:width .3s var(--ease)}
.nav__menu a:hover::after,.nav__menu a.is-active::after{width:100%}
.nav__menu a:hover,.nav__menu a.is-active{color:var(--ink)}
.nav__toggle{display:none}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;
  background:
    radial-gradient(120% 130% at 100% 0%, rgba(21,48,42,.09) 0%, rgba(21,48,42,0) 50%),
    linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%);
  border-bottom:1px solid var(--line-soft);
}
.hero__inner{padding:104px var(--gut) 108px;max-width:var(--maxw);margin:0 auto}
.hero__grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(330px,.66fr);gap:80px;align-items:end}
.hero__lead .eyebrow{margin-bottom:34px}
.hero__lead h1{font-size:78px;line-height:1.13;font-weight:450;color:var(--pine);max-width:9em}
.hero__aside{position:relative;padding-top:38px;border-top:1px solid var(--line)}
.hero__aside p{color:var(--ink-soft);font-size:19px;line-height:2.02;margin-bottom:1.05em}
.hero__aside p:first-child{color:var(--ink)}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:36px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:14px 30px;
  border:1px solid var(--pine);color:var(--pine);
  font-family:"PingFang SC","Hiragino Sans GB",sans-serif;font-size:14.5px;letter-spacing:.05em;
  transition:background .28s var(--ease),color .28s var(--ease),border-color .28s var(--ease);
}
.btn--primary{background:var(--pine);border-color:var(--pine);color:var(--cream)}
.btn:hover{background:var(--brass);border-color:var(--brass);color:#fff}
.btn--primary:hover{background:var(--brass);border-color:var(--brass)}

/* =========================================================
   SECTIONS — uniform rhythm
   ========================================================= */
.section{padding:116px 0}
.section--soft{background:var(--paper-2)}
.section-heading{max-width:840px;margin-bottom:64px}
.section-heading h2{margin-top:28px;font-size:50px;line-height:1.2}

/* intro */
.intro-layout{display:grid;grid-template-columns:220px minmax(0,1fr);gap:90px;align-items:start}
.intro-copy{max-width:790px}
.intro-copy .lead{color:var(--ink);font-size:30px;line-height:1.6;font-weight:450;letter-spacing:.006em;margin-bottom:1.05em}
.intro-copy p{color:var(--ink-soft);font-size:18px;line-height:1.96}

/* statement — the dark editorial pause */
.statement{background:var(--pine);color:var(--cream);position:relative;overflow:hidden}
.statement::before{content:"“";position:absolute;top:-64px;left:42px;font-family:"Cormorant Garamond",Georgia,serif;font-size:320px;line-height:1;color:rgba(207,163,90,.13);pointer-events:none}
.statement__inner{position:relative;max-width:var(--maxw);margin:0 auto;padding:116px var(--gut);display:grid;grid-template-columns:.96fr 1.04fr;gap:84px;align-items:center}
.statement h2{margin-top:28px;font-size:46px;line-height:1.32;color:var(--cream);max-width:13em}
.statement__text{padding-top:8px}
.statement__text p{color:rgba(241,234,216,.7);font-size:18.5px;line-height:2;margin-bottom:1.1em}
.statement__text p:last-child{margin-bottom:0}

/* service cards */
.service-cards{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line)}
.service-cards article{
  padding:46px 34px 52px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);
  display:flex;flex-direction:column;position:relative;transition:background .3s var(--ease);
}
.service-cards article:first-child{border-left:1px solid var(--line)}
.service-cards article::after{content:"";position:absolute;left:0;top:-1px;width:0;height:2px;background:var(--brass);transition:width .4s var(--ease)}
.service-cards article:hover{background:var(--card)}
.service-cards article:hover::after{width:100%}
.service-cards .num{font-family:"Cormorant Garamond",Georgia,serif;font-size:38px;font-weight:500;color:var(--brass);line-height:1;padding-bottom:30px;margin-bottom:30px;border-bottom:1px solid var(--line-soft)}
.service-cards h3{font-size:24px;line-height:1.4;font-weight:600}
.service-cards p{margin-top:18px;color:var(--ink-soft);font-size:15.5px;line-height:1.8}

/* final + entrances */
.final-panel{display:grid;grid-template-columns:.78fr 1.22fr;gap:76px;align-items:center}
.final-copy h2{margin-top:28px;font-size:54px;line-height:1.2}
.final-copy p{margin-top:26px;color:var(--ink-soft);font-size:18px;line-height:1.9;max-width:28ch}
.entrance-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.entrance-cards a{
  min-height:268px;padding:44px 40px;background:var(--card);border:1px solid var(--line);
  display:flex;flex-direction:column;position:relative;overflow:hidden;
  transition:transform .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease);
}
.entrance-cards a::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--brass);transform:scaleY(0);transform-origin:top;transition:transform .4s var(--ease)}
.entrance-cards a:hover{transform:translateY(-5px);border-color:rgba(154,116,47,.42);box-shadow:0 32px 60px -36px rgba(21,48,42,.5)}
.entrance-cards a:hover::before{transform:scaleY(1)}
.entrance-cards strong{display:block;color:var(--pine);font-size:33px;font-weight:600;letter-spacing:.006em}
.entrance-cards p{margin-top:18px;color:var(--ink-soft);font-size:16px;line-height:1.8;flex:1}
.entrance-cards .go{margin-top:28px;font-family:"PingFang SC","Hiragino Sans GB",sans-serif;font-size:13.5px;letter-spacing:.08em;color:var(--pine);transition:color .3s var(--ease)}
.entrance-cards a:hover .go{color:var(--brass)}

/* =========================================================
   PAGE HEAD
   ========================================================= */
.pagehead{
  padding:120px 0 76px;
  background:radial-gradient(110% 150% at 90% -20%, rgba(21,48,42,.08) 0%, rgba(21,48,42,0) 52%), var(--paper);
  border-bottom:1px solid var(--line);
}
.pagehead .index{display:block}
.pagehead h1{margin-top:16px;font-size:60px;line-height:1.1;font-weight:450}
.pagehead p{max-width:46ch;margin-top:28px;color:var(--ink-soft);font-size:19px;line-height:1.8}

/* =========================================================
   DAILY INDEX
   ========================================================= */
.brief-list{border-top:1px solid var(--ink);margin-top:6px}
.brief-row{display:grid;grid-template-columns:130px 1fr 132px;gap:46px;padding:40px 0;border-bottom:1px solid var(--line);align-items:baseline;transition:background .25s var(--ease)}
.brief-row:hover{background:var(--card-2)}
.brief-row__date{font-family:"Cormorant Garamond",Georgia,serif;font-size:33px;font-weight:500;color:var(--brass);line-height:1;letter-spacing:.01em}
.brief-row h2,.brief-row h3{font-size:29px;line-height:1.32;font-weight:600;transition:color .25s var(--ease)}
.brief-row:hover h2,.brief-row:hover h3{color:var(--brass)}
.brief-row p{margin-top:12px;color:var(--ink-soft);font-size:16px;line-height:1.72;max-width:54ch}
.brief-row__stat{text-align:right;font-family:"Cormorant Garamond",Georgia,serif;color:var(--ink-faint);font-size:22px;line-height:1.4}
.brief-row__stat span{display:block;font-family:"PingFang SC","Hiragino Sans GB",sans-serif;font-size:11px;letter-spacing:.1em;margin-top:3px}
.article-meta{margin-top:18px;display:flex;flex-wrap:wrap;gap:8px 18px;font-family:"PingFang SC","Hiragino Sans GB",sans-serif;font-size:11.5px;letter-spacing:.07em;color:var(--ink-faint)}
.article-meta span{position:relative}
.article-meta span+span::before{content:"·";position:absolute;left:-11px;color:var(--line)}

/* pagination */
.pagination{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-top:52px;font-family:"PingFang SC","Hiragino Sans GB",sans-serif;font-size:13px;color:var(--pine)}
.pagination a,.pagination span{min-width:44px;min-height:44px;padding:8px 14px;border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center;transition:background .25s var(--ease),border-color .25s var(--ease),color .25s var(--ease)}
.pagination a:hover,.pagination span[aria-current="page"]{border-color:var(--pine);background:var(--pine);color:var(--cream)}
.pagination .is-disabled{color:var(--ink-faint);opacity:.5}
.pagination__pages{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}

/* =========================================================
   GUIDES
   ========================================================= */
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.guide-card{min-height:336px;padding:42px 36px;background:var(--card);border:1px solid var(--line);display:flex;flex-direction:column;justify-content:space-between;transition:transform .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease)}
.guide-card:hover{transform:translateY(-5px);border-color:rgba(154,116,47,.42);box-shadow:0 30px 56px -36px rgba(21,48,42,.5)}
.guide-card .label{margin-bottom:22px}
.guide-card h2{font-size:29px;line-height:1.32;font-weight:600}
.guide-card p{margin-top:16px;color:var(--ink-soft);font-size:16px;line-height:1.74}
.guide-card .btn{margin-top:30px;align-self:flex-start;min-height:46px;padding:11px 24px}

/* =========================================================
   ARTICLE — magazine-grade daily template
   ========================================================= */
.article-shell{max-width:880px;margin:0 auto;padding:96px var(--gut) 128px}
.article-header{padding-bottom:46px;margin-bottom:14px;border-bottom:1px solid var(--ink)}
.article-kicker{display:flex;align-items:baseline;gap:18px;margin-bottom:26px}
.article-kicker .latin{font-family:"Cormorant Garamond",Georgia,serif;font-size:24px;color:var(--brass);letter-spacing:.02em}
.article-kicker .dot{font-family:"PingFang SC","Hiragino Sans GB",sans-serif;font-size:12.5px;letter-spacing:.12em;color:var(--ink-faint)}
.article-header h1{font-size:54px;line-height:1.18;font-weight:450;margin-bottom:28px}
.article-lede{color:var(--ink-soft);font-size:21px;line-height:1.78}
.article-tags{margin-top:30px;display:flex;flex-wrap:wrap;gap:10px}
.article-tags span{
  font-family:"PingFang SC","Hiragino Sans GB",sans-serif;font-size:12px;letter-spacing:.05em;color:var(--ink-soft);
  padding:6px 14px;border:1px solid var(--line);border-radius:999px;
}
.deal{display:grid;grid-template-columns:78px 1fr;gap:30px;border-top:1px solid var(--line);padding-top:42px;margin-top:48px}
.deal:first-of-type{border-top:0;padding-top:0;margin-top:44px}
.deal__no{font-family:"Cormorant Garamond",Georgia,serif;font-size:46px;font-weight:500;color:var(--brass);line-height:.9}
.deal__meta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.deal__meta span{font-family:"PingFang SC","Hiragino Sans GB",sans-serif;font-size:11.5px;letter-spacing:.08em;color:var(--brass);padding:4px 11px;border:1px solid rgba(154,116,47,.34);border-radius:999px}
.deal h2{font-size:31px;line-height:1.3;font-weight:600}
.deal__verdict{margin-top:18px;font-size:19px;line-height:1.76;color:var(--ink);padding-left:22px;border-left:2px solid var(--brass)}
.deal ul{margin-top:20px;padding-left:20px;color:var(--ink-soft)}
.deal li{margin:10px 0;line-height:1.76}
.deal li::marker{color:var(--brass)}
.note{margin-top:72px;padding:32px 34px;border-left:3px solid var(--brass);background:var(--card-2);color:var(--ink-soft);font-size:15px;line-height:1.84}

/* archive month */
.archive-month{font-family:"Cormorant Garamond",Georgia,serif;font-size:44px;font-weight:500;color:var(--pine);margin:56px 0 8px;letter-spacing:.01em}
.archive-month:first-child{margin-top:0}

/* =========================================================
   FOOTER — matrix band + colophon
   ========================================================= */
.foot{background:var(--pine);color:var(--cream-soft)}
.foot__matrix{border-bottom:1px solid var(--pine-line)}
.matrix__inner{display:grid;grid-template-columns:1fr auto;gap:80px;align-items:center;padding:88px var(--gut)}
.matrix__intro h2{color:var(--cream);font-size:40px;line-height:1.26;font-weight:450;margin:24px 0 24px}
.matrix__chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:30px}
.matrix__chips span{font-family:"PingFang SC","Hiragino Sans GB",sans-serif;font-size:13px;letter-spacing:.04em;color:var(--cream);opacity:.92;padding:7px 16px;border:1px solid var(--pine-line);border-radius:999px}
.matrix__contact{font-family:"PingFang SC","Hiragino Sans GB",sans-serif;font-size:14.5px;letter-spacing:.03em;color:var(--cream-soft)}
.matrix__contact a{color:var(--brass-on-dark);border-bottom:1px solid rgba(207,163,90,.4);padding-bottom:2px;transition:color .25s var(--ease)}
.matrix__contact a:hover{color:var(--cream)}
.matrix__qr{display:flex;gap:22px}
.matrix__qr figure{width:150px;text-align:center}
.matrix__qr img{width:150px;height:150px;background:var(--paper);padding:12px;border-radius:14px}
.matrix__qr figcaption{margin-top:14px;font-family:"PingFang SC","Hiragino Sans GB",sans-serif;font-size:13px;letter-spacing:.06em;color:var(--cream-soft)}

.foot__inner{max-width:var(--maxw);margin:0 auto;padding:74px var(--gut) 38px;text-align:center}
.foot__mark{width:56px;height:56px;margin:0 auto 24px;background:var(--paper);border-radius:50%;padding:5px}
.foot h2{color:var(--cream);font-size:31px;font-weight:600}
.foot h2 i{font-family:"Cormorant Garamond",Georgia,serif;font-style:normal;margin-left:7px}
.foot__inner>p{max-width:46ch;margin:18px auto 38px;color:var(--cream-soft);font-size:15.5px;line-height:1.85}
.foot__nav{display:flex;justify-content:center;flex-wrap:wrap;gap:34px;margin-bottom:46px}
.foot__nav a{font-family:"PingFang SC","Hiragino Sans GB",sans-serif;font-size:13.5px;letter-spacing:.05em;color:var(--cream);opacity:.82;transition:opacity .25s var(--ease),color .25s var(--ease)}
.foot__nav a:hover{opacity:1;color:var(--brass-on-dark)}
.foot__bottom{border-top:1px solid var(--pine-line);padding-top:26px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-family:"PingFang SC","Hiragino Sans GB",sans-serif;font-size:12px;letter-spacing:.04em;color:var(--cream-soft)}

/* =========================================================
   REVEAL
   ========================================================= */
.js [data-reveal]{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.js [data-reveal].in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.js [data-reveal]{opacity:1;transform:none;transition:none}}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1040px){
  .hero__grid,.intro-layout,.statement__inner,.final-panel,.matrix__inner{grid-template-columns:1fr;gap:48px}
  .service-cards{grid-template-columns:repeat(2,1fr)}
  .service-cards article:nth-child(2){border-right:1px solid var(--line)}
  .guide-grid{grid-template-columns:1fr;gap:18px}
  .hero__lead h1{font-size:62px}
  .matrix__qr{justify-content:flex-start}
}
@media(max-width:760px){
  :root{--gut:26px}
  body{font-size:16.5px}
  .nav__inner{padding:15px 26px}
  .brand__sub{display:none}
  .nav__toggle{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border:1px solid var(--line);background:transparent;color:var(--ink);font-family:"PingFang SC",sans-serif;font-size:13px;letter-spacing:.1em;cursor:pointer}
  .nav__menu{display:none;position:absolute;top:71px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:4px;padding:14px 26px 24px;background:rgba(243,238,227,.98);border-bottom:1px solid var(--line)}
  .nav__menu.is-open{display:flex}
  .nav__menu a{padding:12px 0;font-size:16px}
  .hero__inner{padding:60px 26px 74px}
  .hero__grid{gap:38px}
  .hero__lead h1{font-size:45px;line-height:1.2}
  .hero__lead .eyebrow{margin-bottom:24px}
  .hero__aside{padding-top:30px}
  .hero__aside p{font-size:17.5px}
  .section{padding:80px 0}
  .section-heading{margin-bottom:42px}
  .section-heading h2{font-size:35px}
  .chapter b{font-size:26px}
  .intro-copy .lead{font-size:23px}
  .statement__inner{padding:70px 26px}
  .statement h2,.final-copy h2{font-size:34px}
  .statement::before{font-size:200px;top:-32px;left:18px}
  .service-cards{grid-template-columns:1fr}
  .service-cards article{border-right:1px solid var(--line) !important;border-left:1px solid var(--line);padding:38px 28px 42px}
  .entrance-cards{grid-template-columns:1fr}
  .pagehead{padding:78px 0 54px}
  .pagehead h1{font-size:41px}
  .brief-row{grid-template-columns:1fr;gap:8px}
  .brief-row__date{font-size:26px}
  .brief-row__stat{text-align:left}
  .pagination{flex-direction:column}
  .article-shell{padding:60px 26px 88px}
  .article-header h1{font-size:37px}
  .article-lede{font-size:18.5px}
  .deal{grid-template-columns:1fr;gap:14px}
  .deal__no{font-size:38px}
  .matrix__inner{padding:64px 26px}
  .matrix__intro h2{font-size:31px}
  .matrix__qr figure,.matrix__qr img{width:132px}
  .matrix__qr img{height:132px}
  .foot__inner{padding:64px 26px 36px}
  .foot__bottom{justify-content:center;text-align:center;flex-direction:column}
}
