/* ===========================================
   SANSAN — Quiet Luxury v3.0
   =========================================== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
--bg:#f6f3ee;--bg-alt:#f0ece5;--bg-card:#ffffff;
--bg-glass:rgba(246,243,238,.78);--bg-glass-border:rgba(0,0,0,.06);
--text:#1c1a18;--text-light:#7a756d;--text-lighter:#b0aaa0;
--gold:#c49b5e;--gold-light:#dfc9a0;--gold-subtle:rgba(196,155,94,.08);
--gold-glow:rgba(196,155,94,.15);
--border:#e8e2d8;--border-light:#efeae2;
--shadow:rgba(0,0,0,.04);--shadow-float:rgba(0,0,0,.07);
--serif:'Noto Serif SC','Cormorant Garamond','Songti SC',Georgia,serif;
--sans:'Inter',-apple-system,'Segoe UI',system-ui,sans-serif;
--ease:cubic-bezier(.25,.1,.25,1);--ease-out:cubic-bezier(.22,1,.36,1);
--mw-content:740px;--mw-page:1440px;--nav-h:56px;--radius:6px;--radius-sm:4px;
}


html{font-size:16px;-webkit-font-smoothing:antialiased}
body{font-family:var(--sans);font-weight:400;background:var(--bg);color:var(--text);line-height:1.75;min-height:100vh;overflow-x:hidden;transition:background .5s var(--ease),color .5s var(--ease)}
::selection{background:var(--gold);color:#fff}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--text-lighter);border-radius:2px}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ─── Preloader ─── */
.preloader{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .7s var(--ease-out),visibility .7s var(--ease-out)}
.preloader.done{opacity:0;visibility:hidden;pointer-events:none}
.preloader-s{font-family:var(--serif);font-size:2.75rem;letter-spacing:.08em;font-weight:300;opacity:0;animation:prelIn 1s var(--ease-out) .1s forwards}
.preloader-s .g{color:var(--gold)}
.preloader-s .r{color:var(--text)}
.preloader-bar{width:0;height:1px;margin-top:.85rem;background:linear-gradient(90deg,transparent,var(--gold-light),transparent);animation:prelBar 1.2s var(--ease-out) .3s forwards}
.preloader-sub{font-size:.6875rem;color:var(--text-lighter);letter-spacing:.28em;margin-top:.75rem;opacity:0;animation:prelIn .8s var(--ease-out) .6s forwards}
@keyframes prelIn{to{opacity:1}}
@keyframes prelBar{to{width:120px}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes heroLine{from{width:0;opacity:0}to{width:40px;opacity:1}}

@keyframes heroReveal{0%{opacity:0;transform:translateY(20px);filter:blur(4px)}100%{opacity:1;transform:translateY(0);filter:blur(0)}}
@keyframes cardIn{0%{opacity:0;transform:translateY(28px) scale(.97)}60%{transform:translateY(-2px) scale(1)}100%{opacity:1;transform:translateY(0) scale(1)}}
@keyframes dotB{0%,80%,100%{transform:scale(.6);opacity:.3}40%{transform:scale(1);opacity:1}}

/* --- Header --- */
.header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);background:rgba(246,243,238,.85);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-light);transition:transform .4s var(--ease-out)}
.header.hidden{transform:translateY(-100%)}
.header-inner{max-width:var(--mw-page);margin:0 auto;padding:0 28px;height:100%;display:flex;align-items:center;justify-content:space-between}
.site-title{font-family:var(--serif);font-size:1.125rem;letter-spacing:.16em;color:var(--gold);font-weight:500;transition:all .3s var(--ease);position:relative;display:inline-block}
.site-title::after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease-out)}.site-title:hover{opacity:1}.site-title:hover::after{transform:scaleX(1);transform-origin:left}
.header-nav{display:flex;align-items:center;gap:2px}
.nav-item{font-size:.8125rem;letter-spacing:.05em;color:var(--text-light);font-weight:400;padding:6px 10px;transition:color .3s var(--ease);position:relative}
.nav-item::after{content:"";position:absolute;bottom:2px;left:10px;right:10px;height:1.5px;background:var(--gold);transform:scaleX(0);transform-origin:center;transition:transform .3s var(--ease-out)}.nav-item:hover{color:var(--text)}.nav-item:hover::after,.nav-item.active::after{transform:scaleX(1)}
.nav-item.active{color:var(--gold)}
.header-actions{display:flex;align-items:center;gap:8px}
.menu-btn{display:none;width:28px;height:28px;flex-direction:column;justify-content:center;gap:5px}
.menu-btn span{display:block;width:100%;height:1.5px;background:var(--text);border-radius:1px;transition:all .3s var(--ease-out)}
.menu-btn.open span:first-child{transform:translateY(3.25px) rotate(45deg)}
.menu-btn.open span:last-child{transform:translateY(-3.25px) rotate(-45deg)}

/* ─── Mobile Nav ─── */
.mobile-nav{position:fixed;inset:0;z-index:99;pointer-events:none}
.mobile-nav.open{pointer-events:auto}
.mobile-nav-bg{position:absolute;inset:0;background:rgba(0,0,0,.3);opacity:0;transition:opacity .4s var(--ease-out)}
.mobile-nav.open .mobile-nav-bg{opacity:1}
.mobile-nav-links{position:absolute;top:0;right:0;bottom:0;width:280px;background:var(--bg);padding:5rem 2rem 2rem;display:flex;flex-direction:column;gap:4px;transform:translateX(100%);transition:transform .4s var(--ease-out);border-left:1px solid var(--border);will-change:transform}
.mobile-nav.open .mobile-nav-links{transform:translateX(0)}
.mobile-link{font-family:var(--serif);font-size:1.125rem;letter-spacing:.06em;color:var(--text-light);padding:10px 16px;border-radius:var(--radius-sm);transition:all .3s var(--ease)}
.mobile-link:hover{color:var(--text);background:var(--gold-subtle)}

/* ─── Page ─── */
.page{min-height:100vh;padding-top:var(--nav-h);opacity:0;transform:translateY(12px);transition:opacity .5s var(--ease-out),transform .5s var(--ease-out)}
.page.active{opacity:1;transform:translateY(0)}
.page.exit{opacity:0;transform:translateY(-10px)}

/* ═══════════════════════════════════════
   HOME
   ═══════════════════════════════════════ */
.hero{position:relative;z-index:1;padding:5rem 28px 3rem;text-align:center;overflow:hidden}
.hero::before{content:'';position:absolute;top:-40%;left:50%;translate:-50% 0;width:600px;height:600px;background:radial-gradient(ellipse,var(--gold-glow) 0%,transparent 65%);pointer-events:none}
.hero-line{width:40px;height:1px;background:var(--gold);margin:0 auto 1.75rem;animation:heroLine 1.2s var(--ease-out) .3s both}
.hero h1{font-family:var(--serif);font-size:3.5rem;font-weight:300;letter-spacing:.18em;color:var(--text);line-height:1.15;animation:heroReveal 1s var(--ease-out) .15s both}
.hero .hero-desc{margin-top:1.25rem;font-size:.875rem;color:var(--text-lighter);letter-spacing:.06em;font-weight:300;max-width:420px;margin-left:auto;margin-right:auto;line-height:1.9;animation:heroReveal 1s var(--ease-out) .7s both}
.hero-divider{display:flex;justify-content:center;align-items:center;gap:8px;margin:.9rem auto .7rem;animation:heroReveal 1s var(--ease-out) .35s both}
.hero-divider span{display:block;width:24px;height:1px;background:var(--gold-light);opacity:.6}
.hero-tagline{font-family:var(--serif);font-size:.9375rem;letter-spacing:.22em;color:var(--text-light);font-weight:300;line-height:1.6;animation:heroReveal 1s var(--ease-out) .5s both}
.hero-ornament{display:flex;justify-content:center;align-items:center;gap:10px;margin-top:.9rem;animation:heroReveal 1s var(--ease-out) .6s both}
.hero-ornament span{display:block;width:32px;height:1px;background:linear-gradient(90deg,transparent,var(--border));opacity:.5}
.hero-ornament .hero-dot{width:auto;height:auto;background:none;font-size:.5rem;color:var(--gold-light);opacity:.7;letter-spacing:0}


.content-wrap{max-width:var(--mw-page);margin:0 auto;padding:0 28px 3rem;display:grid;grid-template-columns:1fr 300px;gap:2.5rem}
.main-content{min-width:0}
.section-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.22em;color:var(--gold);margin-bottom:.5rem;font-weight:500}
.section-title{font-family:var(--serif);font-size:1.5rem;font-weight:400;letter-spacing:.04em;color:var(--text);margin-bottom:1.5rem}
.grid-3col{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:2.5rem}

.post-card{background:var(--bg-card);border-radius:6px;overflow:hidden;cursor:pointer;border:1px solid var(--border-light);display:flex;flex-direction:column;opacity:0;transform:translateY(24px);transition:transform .8s cubic-bezier(.22,1,.36,1),opacity .8s cubic-bezier(.22,1,.36,1),box-shadow .5s cubic-bezier(.22,1,.36,1),border-color .4s var(--ease-out);transition-delay:var(--card-delay,.1s);will-change:transform,opacity;box-shadow:0 1px 3px var(--shadow)}
.post-card.card-visible{opacity:1;transform:translateY(0)}

.post-card.card-visible{opacity:1;transform:translateY(0)}
.post-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px var(--shadow-float);border-color:var(--gold-light)}
.post-card-img{aspect-ratio:16/9;overflow:hidden;background:var(--bg-alt);flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--text-lighter);font-size:.75rem}
.post-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out)}
.post-card:hover .post-card-img img{transform:scale(1.05)}
.post-card-body{padding:1rem 1.25rem 1.25rem;flex:1;display:flex;flex-direction:column}
.post-card-cat{font-size:.625rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:.35rem;font-weight:500}
.post-card-title{font-family:var(--serif);font-size:1rem;font-weight:400;line-height:1.4;margin-bottom:.5rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.post-card-excerpt{font-size:.8125rem;color:var(--text-light);line-height:1.65;margin-bottom:.75rem;flex:1}
.post-card-date{font-size:.6875rem;color:var(--text-lighter);font-feature-settings:'tnum';margin-top:auto}
@keyframes cardIn{0%{opacity:0;transform:translateY(24px)}60%{transform:translateY(-3px)}100%{opacity:1;transform:translateY(0)}}

/* ═══════════════════════════════════════
   SIDEBAR
   ═══════════════════════════════════════ */
.sidebar{min-width:0}
.sidebar-section{margin-bottom:2rem;content-visibility:auto;contain-intrinsic-size:200px}
.sidebar-head{font-size:.625rem;text-transform:uppercase;letter-spacing:.2em;color:var(--gold);font-weight:500;padding-bottom:.6rem;margin-bottom:.75rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.sidebar-head::after{content:'';flex:1;height:1px;background:var(--border)}
.search-wrap{position:relative}
.search-wrap input{width:100%;padding:9px 36px 9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-alt);color:var(--text);font-size:.8125rem;font-family:var(--sans);outline:none;transition:all .3s var(--ease)}
.search-wrap input::placeholder{color:var(--text-lighter);font-weight:300}
.search-wrap input:focus{border-color:var(--gold-light);box-shadow:0 0 0 3px var(--gold-subtle);background:var(--bg-card)}
.search-wrap .search-icon{position:absolute;right:10px;top:50%;translate:0 -50%;color:var(--text-lighter);pointer-events:none}
.search-results{margin-top:8px;display:none;flex-direction:column;gap:4px;max-height:280px;overflow-y:auto}
.search-results.show{display:flex}
.search-result-item{padding:8px 10px;border-radius:var(--radius-sm);font-size:.8125rem;color:var(--text-light);cursor:pointer;transition:all .2s var(--ease)}
.search-result-item:hover{background:var(--gold-subtle);color:var(--text)}
.search-result-item .s-match{color:var(--gold)}
.search-empty{padding:12px 10px;font-size:.8125rem;color:var(--text-lighter);text-align:center}
.recent-item{display:flex;justify-content:space-between;align-items:baseline;gap:8px;padding:.55rem 0;cursor:pointer;border-bottom:1px solid var(--border-light);transition:opacity .3s var(--ease)}
.recent-item:first-of-type{padding-top:0}
.recent-item:hover{opacity:.7}
.recent-item-title{font-family:var(--serif);font-size:.875rem;letter-spacing:.02em;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.recent-item-date{font-size:.625rem;color:var(--text-lighter);white-space:nowrap;font-feature-settings:'tnum'}
.archive-item{display:flex;justify-content:space-between;align-items:center;padding:.45rem 0;border-bottom:1px solid var(--border-light);cursor:pointer;transition:opacity .3s var(--ease)}
.archive-item:hover{opacity:.7}
.archive-item-label{font-size:.875rem;font-family:var(--serif);letter-spacing:.04em}
.archive-item-count{font-size:.625rem;color:var(--text-lighter);background:var(--bg-alt);padding:1px 8px;border-radius:99px;font-feature-settings:'tnum'}
.cat-tags{display:flex;flex-wrap:wrap;gap:6px}
.cat-tag{padding:3px 12px;border-radius:99px;font-size:.6875rem;color:var(--text-light);background:var(--bg-alt);border:1px solid var(--border-light);cursor:pointer;transition:all .3s var(--ease)}
.cat-tag:hover{color:var(--gold);border-color:var(--gold-light);background:var(--gold-subtle)}
.sidebar-about{font-size:.875rem;color:var(--text-light);line-height:1.8}
.sidebar-about .gold-dot{display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--gold);margin:0 2px;vertical-align:middle}

/* ═══════════════════════════════════════
   FULL-WIDTH ARTICLE PAGE
   ═══════════════════════════════════════ */

/* Article page overrides padding-top (handled by article-wrap) */
.article-page{padding-top:0;display:flex;flex-direction:column}
.article-page.active{transform:translateY(0)}
.article-loading{display:flex;align-items:center;justify-content:center;height:calc(100vh - var(--nav-h))}

/* ─── Article Top Bar ─── */
.article-wrap{display:flex;flex-direction:column;height:calc(100vh - var(--nav-h))}

/* ─── Article Iframe ─── */
.article-iframe-wrap{flex:1;display:flex;min-height:0}
.article-frame{width:100%;border:none;display:block;height:100%}

/* ─── Floating overlay controls ─── */
.art-float{
position:fixed;z-index:101;top:64px;
display:flex;align-items:center;gap:6px;
font-size:.8125rem;color:var(--text-light);letter-spacing:.04em;
padding:7px 14px;border-radius:var(--radius-sm);
background:var(--bg-card);
border:1px solid var(--border-light);
cursor:pointer;transition:all .3s var(--ease-out);
opacity:0.55;pointer-events:auto;
}
.art-float svg{width:15px;height:15px}
.art-float-back{left:12px}
.art-float-fs{right:12px}
.art-float-fs .fs-icon-exit{display:none}

.art-float:hover{opacity:1}
.art-float:focus-visible{opacity:1}
.art-float:hover{color:var(--text);border-color:var(--gold-light);background:var(--bg-card)}

.sansan-fullscreen .art-float{top:16px}
.sansan-fullscreen .art-float-fs .fs-icon{display:none}
.sansan-fullscreen .art-float-fs .fs-icon-exit{display:block}

/* ═══════════════════════════════════════
   FULLSCREEN MODE — Only hides main nav
   ═══════════════════════════════════════ */
.sansan-fullscreen .header{transform:translateY(-100%)}
.sansan-fullscreen .footer{display:none}
.sansan-fullscreen .article-iframe-wrap{height:100vh}

/* ═══════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════ */
.footer{border-top:1px solid var(--border-light);padding:2rem 28px}
.footer-inner{max-width:var(--mw-page);margin:0 auto;display:flex;align-items:center;justify-content:space-between}
.footer-brand{font-family:var(--serif);font-size:.9375rem;letter-spacing:.14em;color:var(--text);opacity:.4}
.footer-links{display:flex;gap:1.5rem}
.footer-links a{font-size:.6875rem;color:var(--text-lighter);transition:color .3s var(--ease);letter-spacing:.04em}
.footer-links a:hover{color:var(--text)}
.footer-copy{font-size:.6875rem;color:var(--text-lighter);font-feature-settings:'tnum'}

/* ═══════════════════════════════════════
   STATES
   ═══════════════════════════════════════ */
.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:12px}
.loading-dots{display:flex;gap:5px}
.loading-dots span{width:5px;height:5px;border-radius:50%;background:var(--text-lighter);animation:dotB 1.4s ease-in-out infinite both}
.loading-dots span:nth-child(1){animation-delay:-.32s}
.loading-dots span:nth-child(2){animation-delay:-.16s}
.loading-dots span:nth-child(3){animation-delay:0s}
@keyframes dotB{0%,80%,100%{transform:scale(.6);opacity:.3}40%{transform:scale(1);opacity:1}}
.error-state{text-align:center;padding:4rem 2rem;color:var(--text-lighter)}
.error-state p{font-size:.875rem;margin-top:.5rem}

/* ═══════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════ */
/* ─── Content Loader ─── */
.content-spinner{width:28px;height:28px;border:1.5px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}
.content-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 0;gap:.75rem}

@media(max-width:960px){
.content-wrap{grid-template-columns:1fr;gap:2.5rem}
.hero h1{font-size:3.25rem}
.grid-3col{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
.header-inner{padding:0 16px}
.header-nav{display:none}
.menu-btn{display:flex}
.hero{padding:2rem 12px 1.25rem}
.hero::before{width:400px;height:400px}
.hero h1{font-size:3rem}
.hero h1 em{font-size:1.5rem}
.hero p{font-size:1.125rem}
.hero-line{margin-bottom:1.25rem}
.content-wrap{padding:0 12px 1.5rem;grid-template-columns:1fr}
.section-title{font-size:1.25rem;margin-bottom:1rem}
.grid-3col{grid-template-columns:1fr;gap:.625rem}
.post-card{flex-direction:column}
.post-card-img{aspect-ratio:16/9;width:100%;min-height:auto;border-radius:6px 6px 0 0}
.post-card-body{padding:.75rem .875rem 1rem}
.post-card-title{font-size:.9375rem}
.post-card-excerpt{font-size:.8125rem;line-height:1.45}
.post-card-date{font-size:.6875rem}
.footer-inner{flex-direction:column;gap:4px;text-align:center}
.footer-links{gap:.75rem}
.sidebar-section{margin-bottom:.75rem}
}
@media(max-width:480px){
.hero{padding:2rem 12px 1.25rem}
.hero::before{width:200px;height:200px}
.hero h1{font-size:3.25rem}
.hero h1 em{font-size:1.125rem}
.hero p{font-size:1.0625rem}
.section-title{font-size:1.125rem}
.grid-3col{grid-template-columns:1fr;gap:.5rem}
.post-card{flex-direction:column;border-radius:8px}
.post-card-img{aspect-ratio:16/9;width:100%;min-height:auto;border-radius:6px 6px 0 0;background:var(--bg-alt)}
.post-card-body{padding:.625rem .75rem .875rem}
.post-card-title{font-size:.875rem}
.post-card-excerpt{font-size:.8125rem;line-height:1.5}
.post-card-date{font-size:.6875rem}
.site-title{font-size:1rem}
}

@keyframes glowPulse{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.12)}}

/* --- Hero rings & dots --- */
.hero-ring{position:absolute;border-radius:50%;border:1px solid var(--gold-light);top:50%;left:50%;pointer-events:none}
.hero-ring-1{width:520px;height:520px;opacity:.15;animation:heroRing1 28s ease-in-out infinite;transform:translate(-50%,-50%)}
.hero-ring-2{width:360px;height:360px;opacity:.1;border-color:var(--gold);animation:heroRing2 22s ease-in-out infinite reverse;transform:translate(-50%,-50%)}
@keyframes heroRing1{0%,100%{transform:translate(-50%,-50%) rotate(0deg)}33%{transform:translate(-44%,-46%) rotate(4deg)}66%{transform:translate(-56%,-54%) rotate(-3deg)}}
@keyframes heroRing2{0%,100%{transform:translate(-50%,-50%) rotate(0deg)}33%{transform:translate(-46%,-44%) rotate(-3deg)}66%{transform:translate(-54%,-56%) rotate(4deg)}}
.hero-gdot{position:absolute;width:5px;height:5px;border-radius:50%;background:var(--gold);pointer-events:none}
.hero-gdot-1{top:18%;left:12%;opacity:.35;animation:heroGdot1 8s ease-in-out infinite}
.hero-gdot-2{bottom:22%;right:10%;opacity:.25;animation:heroGdot2 10s ease-in-out infinite 1s}
.hero-gdot-3{top:35%;right:20%;opacity:.2;animation:heroGdot3 7s ease-in-out infinite 2s}
@keyframes heroGdot1{0%,100%{transform:translate(0,0);opacity:.35}50%{transform:translate(14px,-10px);opacity:.6}}
@keyframes heroGdot2{0%,100%{transform:translate(0,0);opacity:.25}50%{transform:translate(-12px,-12px);opacity:.5}}
@keyframes heroGdot3{0%,100%{transform:translate(0,0);opacity:.2}50%{transform:translate(10px,12px);opacity:.45}}

/* --- Hero title group & chop --- */
.hero-title-group{display:flex;align-items:center;justify-content:center;gap:0.75rem}
.hero-chop{width:40px;height:40px;background:#c43a31;color:#fff;font-size:1.125rem;display:flex;align-items:center;justify-content:center;font-family:'Noto Serif SC',serif;border-radius:4px;opacity:0.85;transform:rotate(-2deg);flex-shrink:0;transition:transform 0.5s var(--ease-out),box-shadow 0.5s var(--ease-out);box-shadow:0 2px 8px rgba(196,58,49,0.15);cursor:pointer;line-height:1;position:relative}
.hero-chop:hover{transform:rotate(0deg) scale(1.05);box-shadow:0 4px 16px rgba(196,58,49,0.25)}

/* --- Hero rings & dots --- */
.hero-ring{position:absolute;border-radius:50%;border:1px solid var(--gold-light);top:50%;left:50%;pointer-events:none}
.hero-ring-1{width:520px;height:520px;opacity:.15;animation:heroRing1 28s ease-in-out infinite;transform:translate(-50%,-50%)}
.hero-ring-2{width:360px;height:360px;opacity:.1;border-color:var(--gold);animation:heroRing2 22s ease-in-out infinite reverse;transform:translate(-50%,-50%)}
@keyframes heroRing1{0%,100%{transform:translate(-50%,-50%) rotate(0deg)}33%{transform:translate(-44%,-46%) rotate(4deg)}66%{transform:translate(-56%,-54%) rotate(-3deg)}}
@keyframes heroRing2{0%,100%{transform:translate(-50%,-50%) rotate(0deg)}33%{transform:translate(-46%,-44%) rotate(-3deg)}66%{transform:translate(-54%,-56%) rotate(4deg)}}
.hero-gdot{position:absolute;width:5px;height:5px;border-radius:50%;background:var(--gold);pointer-events:none}
.hero-gdot-1{top:18%;left:12%;opacity:.35;animation:heroGdot1 8s ease-in-out infinite}
.hero-gdot-2{bottom:22%;right:10%;opacity:.25;animation:heroGdot2 10s ease-in-out infinite 1s}
.hero-gdot-3{top:35%;right:20%;opacity:.2;animation:heroGdot3 7s ease-in-out infinite 2s}
@keyframes heroGdot1{0%,100%{transform:translate(0,0);opacity:.35}50%{transform:translate(14px,-10px);opacity:.6}}
@keyframes heroGdot2{0%,100%{transform:translate(0,0);opacity:.25}50%{transform:translate(-12px,-12px);opacity:.5}}
@keyframes heroGdot3{0%,100%{transform:translate(0,0);opacity:.2}50%{transform:translate(10px,12px);opacity:.45}}

/* --- Hero title group & chop --- */
.hero-title-group{display:flex;align-items:center;justify-content:center;gap:0.75rem}
.hero-chop{width:40px;height:40px;background:#c43a31;color:#fff;font-size:1.125rem;display:flex;align-items:center;justify-content:center;font-family:'Noto Serif SC',serif;border-radius:4px;opacity:0.85;transform:rotate(-2deg);flex-shrink:0;transition:transform 0.5s var(--ease-out),box-shadow 0.5s var(--ease-out);box-shadow:0 2px 8px rgba(196,58,49,0.15);cursor:pointer;line-height:1;position:relative}
.hero-chop:hover{transform:rotate(0deg) scale(1.05);box-shadow:0 4px 16px rgba(196,58,49,0.25)}

/* --- Hero content wrapper --- */
.hero-content{position:relative;z-index:1;max-width:560px;margin:0 auto}

/* --- Hero badge --- */
.hero-badge{display:inline-flex;align-items:center;gap:0.75rem;margin-bottom:1.5rem}
.hero-badge-line{display:block;width:28px;height:1px;background:var(--gold);opacity:0.35}
.hero-badge-text{font-size:0.75rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--gold);font-weight:400}

/* --- Hero sub (italic tagline) --- */
.hero-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.25rem;color:var(--text-light);line-height:1.6;margin-bottom:0.5rem;font-weight:300;letter-spacing:0.05em}

/* --- Hero scroll --- */
.hero-scroll{display:inline-flex;flex-direction:column;align-items:center;gap:0.5rem;color:var(--text-lighter);font-size:0.6875rem;letter-spacing:0.15em;animation:scrollBounce 2.4s var(--ease-out) infinite}
.hero-scroll::after{content:'';display:block;width:1px;height:24px;background:var(--text-lighter)}
@keyframes scrollBounce{0%,100%{transform:translateY(0);opacity:0.5}50%{transform:translateY(6px);opacity:1}}

/* --- Home about section --- */
.home-about{padding:3rem 28px 4rem;text-align:center;border-top:1px solid var(--border-light);max-width:var(--mw-content);margin:0 auto}
.home-about p{font-size:0.9375rem;color:var(--text-light);line-height:1.9;font-weight:300}
.home-about p:first-child{margin-bottom:0.25rem}

/* --- Chop stamp interaction --- */
@keyframes chopStamp{0%{transform:rotate(-2deg) scale(1);box-shadow:0 2px 8px rgba(196,58,49,0.15)}10%{transform:rotate(-1deg) scale(0.82);box-shadow:0 1px 4px rgba(196,58,49,0.25)}25%{transform:rotate(2deg) scale(0.88)}40%{transform:rotate(-1deg) scale(0.85)}60%{transform:rotate(0deg) scale(0.94);box-shadow:0 3px 16px rgba(196,58,49,0.35)}80%{transform:rotate(-1deg) scale(1.02)}100%{transform:rotate(-2deg) scale(1);box-shadow:0 2px 8px rgba(196,58,49,0.15)}}
.hero-chop.stamping{animation:chopStamp 0.7s cubic-bezier(.22,1,.36,1) forwards}
.hero-chop::after{content:'';position:absolute;top:50%;left:50%;width:0;height:0;border:2px solid rgba(196,58,49,0);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;transition:none}
.hero-chop.stamping::after{animation:chopInkRing 0.7s ease-out forwards}
@keyframes chopInkRing{0%{width:0;height:0;border-color:rgba(196,58,49,0.5);border-width:3px;opacity:1}100%{width:80px;height:80px;border-color:rgba(196,58,49,0);border-width:1px;opacity:0}}

/* ─── Achievement ─── */
.ach-container{position:fixed;bottom:24px;right:24px;z-index:9998;display:flex;flex-direction:column-reverse;gap:10px;pointer-events:none}
.ach-toast{display:flex;align-items:stretch;width:340px;min-height:76px;background:rgba(30,28,26,.92);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.08);border-radius:6px;overflow:hidden;transform:translateX(120%) scale(.9);opacity:0;transition:transform .5s cubic-bezier(.22,1,.36,1),opacity .4s ease;pointer-events:auto;box-shadow:0 8px 40px rgba(0,0,0,.3)}
.ach-toast.show{transform:translateX(0) scale(1);opacity:1}
.ach-toast.exit{transform:translateX(40%) scale(.95);opacity:0;transition-duration:.35s}
.ach-icon-wrap{width:68px;min-height:76px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(196,155,94,.18),rgba(196,155,94,.06));flex-shrink:0;border-right:1px solid rgba(255,255,255,.06)}
.ach-icon{font-size:1.75rem;line-height:1;filter:drop-shadow(0 0 6px rgba(196,155,94,.25))}
.ach-body{flex:1;padding:12px 16px;display:flex;flex-direction:column;justify-content:center;min-width:0}
.ach-label{font-size:.5625rem;text-transform:uppercase;letter-spacing:.18em;color:#c49b5e;font-weight:500;margin-bottom:1px}
.ach-title{font-family:var(--serif);font-size:.875rem;font-weight:500;color:#f0ece6;line-height:1.3;letter-spacing:.02em}
.ach-desc{font-size:.6875rem;color:rgba(255,255,255,.5);line-height:1.4;margin-top:1px}
.ach-bar-wrap{height:2px;background:rgba(255,255,255,.08);margin:6px 12px 10px;border-radius:1px;overflow:hidden;flex-shrink:0}
.ach-bar{height:100%;background:#c49b5e;width:0;border-radius:1px;transition:width 3s linear}
.ach-toast.show .ach-bar{width:100%}
@media(max-width:480px){.ach-container{bottom:16px;right:16px;left:16px}.ach-toast{width:100%;min-height:68px}.ach-icon-wrap{width:56px;min-height:68px}.ach-icon{font-size:1.4rem}.ach-title{font-size:.8125rem}.ach-desc{font-size:.625rem}}

/* ─── Achievement mobile scale ─── */
@media(max-width:480px){
.ach-toast{width:280px;min-height:60px}
.ach-icon-wrap{width:52px;min-height:60px}
.ach-icon{font-size:1.3rem}
.ach-title{font-size:.8125rem}
.ach-label{font-size:.5rem}
.ach-desc{font-size:.625rem}
.ach-bar-wrap{margin:4px 10px 8px}
}
