:root{--bg:#ECE2CC;--bg-warm:#E6D9BD;--bg-soft:#E0D2B0;--bg-card:#F1E9D4;--bg-deep:#2D2418;--ink:#1A1612;--ink-soft:#443A2D;--ink-muted:#8A7C64;--walnut:#5B3D24;--walnut-deep:#1F140C;--oxblood:#6B3531;--oxblood-deep:#3D1E1B;--copper:#B27851;--copper-deep:#8B5A38;--copper-soft:#C99878;--line:#C2B189;--line-soft:#D4C5A1;--safe-bottom:env(safe-area-inset-bottom,0px);--safe-top:env(safe-area-inset-top,0px)}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,system-ui,sans-serif;font-weight:300;background:var(--bg);color:var(--ink);line-height:1.7;font-size:17px;-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;overflow-x:hidden;position:relative}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.reveal{opacity:1!important;transform:none!important}#heroCanvas{display:none}}
section[id]{scroll-margin-top:80px}
.skip-link{position:absolute;top:-100px;left:1rem;background:var(--ink);color:var(--bg);padding:.65rem 1.1rem;text-decoration:none;z-index:200;font-size:.85rem;border-radius:2px;font-family:'Fraunces',Georgia,serif;font-style:italic}
.skip-link:focus{top:calc(1rem + var(--safe-top))}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:1;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.1 0 0 0 0 0.08 0 0 0 0 0.05 0 0 0 0.55 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");opacity:.18;mix-blend-mode:multiply}
::selection{background:var(--copper);color:var(--bg)}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:300;letter-spacing:-.02em;color:var(--ink)}
nav.top{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.25rem 2rem;padding-top:calc(1.25rem + var(--safe-top));background:rgba(236,226,204,.82);backdrop-filter:blur(14px) saturate(1.2);-webkit-backdrop-filter:blur(14px) saturate(1.2);border-bottom:1px solid transparent;transition:border-color .3s,padding .3s}
nav.top.scrolled{border-bottom-color:var(--line);padding:.9rem 2rem;padding-top:calc(.9rem + var(--safe-top))}
nav.top .inner{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:2rem}
nav.top .brand{font-family:'Fraunces',Georgia,serif;font-size:1.05rem;font-weight:400;color:var(--ink);text-decoration:none;justify-self:start;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
nav.top .brand .mark{display:inline-block;width:8px;height:8px;background:var(--copper);border-radius:50%;margin-right:.65rem;vertical-align:middle;transform:translateY(-1px)}
nav.top .brand .sub{color:var(--ink-muted);font-style:italic;font-weight:300;margin-left:.35rem}
nav.top ul{display:flex;list-style:none;gap:2.5rem;font-size:.83rem;letter-spacing:.04em}
nav.top ul a{color:var(--ink-soft);text-decoration:none;transition:color .25s;position:relative;padding:.25rem 0}
@media (hover:hover){nav.top ul a:hover{color:var(--copper-deep)}nav.top ul a:hover::after{width:100%}}
nav.top ul a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--copper-deep);transition:width .35s}
.lang-toggle{justify-self:end;display:flex;align-items:center;font-family:'Fraunces',Georgia,serif;font-size:.85rem;letter-spacing:.06em}
.lang-toggle button[data-lang]{background:none;border:none;cursor:pointer;padding:.45rem .55rem;color:var(--ink-muted);font-family:inherit;font-size:inherit;letter-spacing:inherit;transition:color .25s;-webkit-tap-highlight-color:transparent;min-height:44px;min-width:44px}
.lang-toggle button[data-lang].active{color:var(--ink);font-style:italic}
.lang-toggle .sep{color:var(--line)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--ink);padding:.5rem;margin-left:.25rem;-webkit-tap-highlight-color:transparent;min-height:44px;min-width:44px}
@media (max-width:880px){nav.top .inner{grid-template-columns:1fr auto;gap:1rem}nav.top ul{display:none}nav.top ul.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--bg);padding:1rem 1.5rem 2rem;border-bottom:1px solid var(--line);box-shadow:0 8px 24px rgba(45,36,24,.06)}nav.top ul.open li{padding:.85rem 0;border-bottom:1px solid var(--line-soft)}nav.top ul.open li:last-child{border-bottom:none}nav.top ul.open a{font-size:1rem}.menu-toggle{display:inline-flex;align-items:center}}
@media (max-width:520px){nav.top .brand .sub{display:none}nav.top{padding:1rem 1.25rem;padding-top:calc(1rem + var(--safe-top))}nav.top.scrolled{padding:.8rem 1.25rem;padding-top:calc(.8rem + var(--safe-top))}.lang-toggle{font-size:.8rem}.lang-toggle button[data-lang]{padding:.45rem .4rem}}
section{padding:7rem 2rem;position:relative;z-index:2}
.container{max-width:1180px;margin:0 auto}
.narrow{max-width:740px;margin:0 auto}
.label{font-family:'Fraunces',Georgia,serif;font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;color:var(--copper-deep);margin-bottom:1.75rem;font-weight:400;display:inline-flex;align-items:center;gap:.8rem}
.label::before{content:'';width:32px;height:1px;background:var(--copper)}
.label.center{justify-content:center}
.hero{min-height:100vh;min-height:100svh;min-height:100dvh;display:flex;align-items:center;justify-content:center;text-align:center;padding:8rem 2rem 6rem;padding-top:calc(8rem + var(--safe-top));position:relative;overflow:hidden}
#heroCanvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:.6}
.hero-vignette{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse at center,transparent 30%,var(--bg) 85%);pointer-events:none}
.hero-content{position:relative;z-index:2;max-width:100%}
.hero .eyebrow{font-family:'Fraunces',Georgia,serif;font-size:clamp(.7rem,2.2vw,.78rem);letter-spacing:.32em;text-transform:uppercase;color:var(--copper-deep);margin-bottom:2.5rem;font-weight:400}
.hero h1{font-size:clamp(2.8rem,11vw,8rem);line-height:.95;margin-bottom:1.75rem;font-weight:200;letter-spacing:-.035em;word-break:keep-all;overflow-wrap:break-word}
.hero h1 .accent{font-style:italic;color:var(--copper);font-weight:300}
.hero .subtitle{font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:300;font-size:clamp(1.05rem,2.4vw,1.4rem);color:var(--ink-soft);max-width:560px;margin:0 auto 3rem;line-height:1.55;padding:0 .5rem}
.hero .author-tag{font-family:'Fraunces',Georgia,serif;font-size:clamp(.7rem,2vw,.8rem);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-muted);font-weight:400}
.hero .author-tag::before,.hero .author-tag::after{content:'·';margin:0 .8rem;color:var(--copper)}
.scroll-cue{position:absolute;bottom:calc(2.5rem + var(--safe-bottom));left:50%;transform:translateX(-50%);font-family:'Fraunces',Georgia,serif;font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-muted);z-index:2}
.scroll-cue::after{content:'';display:block;width:1px;height:36px;background:var(--copper);margin:.85rem auto 0;animation:drop 2.4s ease-in-out infinite;transform-origin:top}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@media (max-height:600px) and (orientation:landscape){.scroll-cue{display:none}.hero{padding:5rem 2rem 3rem}}
.philosophy{background:var(--bg-warm);text-align:center;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.ornament{font-family:'Fraunces',Georgia,serif;font-style:italic;color:var(--copper);font-size:1.5rem;margin-bottom:1.75rem;letter-spacing:.3em}
.philosophy .lead{font-family:'Fraunces',Georgia,serif;font-size:clamp(1.4rem,3vw,2.2rem);line-height:1.45;color:var(--ink);font-weight:300;letter-spacing:-.015em}
.philosophy .lead em{color:var(--copper-deep);font-style:italic}
.philosophy .body{margin-top:2.5rem;font-size:1.05rem;color:var(--ink-soft);line-height:1.8;max-width:620px;margin-left:auto;margin-right:auto}
.themes h2{font-size:clamp(2rem,4.5vw,3.4rem);margin-bottom:1rem;text-align:center;font-weight:300}
.themes .intro{text-align:center;color:var(--ink-soft);max-width:600px;margin:0 auto 5rem;font-style:italic;font-family:'Fraunces',Georgia,serif;font-size:1.1rem;padding:0 1rem}
.themes-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media (max-width:1000px){.themes-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.themes-grid{grid-template-columns:1fr}}
.theme-card{background:var(--bg-card);padding:2.5rem 1.75rem 2.25rem;text-decoration:none;color:var(--ink);transition:background .5s;display:flex;flex-direction:column;gap:.9rem;min-height:220px;position:relative;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent}
@media (hover:hover){.theme-card:hover{background:var(--bg)}.theme-card:hover::before{width:100%}.theme-card:hover .arrow{opacity:1;transform:translateX(0)}.theme-card:hover .arrow::after{transform:translateX(4px)}}
.theme-card:focus-visible{background:var(--bg);outline:2px solid var(--copper);outline-offset:-2px}
.theme-card::before{content:'';position:absolute;top:0;left:0;width:0;height:1px;background:var(--copper-deep);transition:width .55s}
.theme-card .num{font-family:'Fraunces',Georgia,serif;font-size:.9rem;color:var(--copper);font-style:italic;letter-spacing:.05em}
.theme-card h3{font-size:clamp(1.35rem,2.5vw,1.5rem);line-height:1.15;font-weight:300;letter-spacing:-.015em}
.theme-card p{font-size:.9rem;color:var(--ink-soft);line-height:1.6;margin-top:auto}
.theme-card .arrow{margin-top:1rem;font-family:'Fraunces',Georgia,serif;font-size:.78rem;letter-spacing:.18em;color:var(--copper-deep);text-transform:uppercase;font-style:italic;opacity:1;transform:translateX(0);transition:opacity .4s,transform .4s;display:inline-flex;align-items:center;gap:.5rem}
.theme-card .arrow::after{content:'→';font-style:normal;transition:transform .4s}
@media (hover:hover){.theme-card .arrow{opacity:0;transform:translateX(-8px)}}
.pull-quote{background:var(--bg-deep);color:var(--bg);padding:8rem 2rem;text-align:center;position:relative;overflow:hidden}
.pull-quote::before{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n2'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.92 0 0 0 0 0.82 0 0 0 0 0.62 0 0 0 0.45 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n2)'/%3E%3C/svg%3E");opacity:.18;mix-blend-mode:overlay;pointer-events:none}
.pull-quote .mark{font-family:'Fraunces',Georgia,serif;font-style:italic;font-size:5rem;line-height:0;color:var(--copper-soft);opacity:.8;margin-bottom:1rem;display:inline-block;transform:translateY(2rem)}
.pull-quote q{font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:200;font-size:clamp(1.5rem,4vw,3.2rem);line-height:1.35;letter-spacing:-.02em;quotes:none;display:block;max-width:920px;margin:0 auto 2.5rem;position:relative}
.pull-quote q::before,.pull-quote q::after{content:none}
.pull-quote .attribution{font-family:'Fraunces',Georgia,serif;font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;color:var(--copper-soft);font-weight:400}
.exercise{background:var(--bg-warm);position:relative}
.exercise h2{font-size:clamp(2rem,4.5vw,3.4rem);text-align:center;margin-bottom:1rem;font-weight:300}
.exercise .intro{text-align:center;font-style:italic;font-family:'Fraunces',Georgia,serif;color:var(--ink-soft);margin-bottom:5rem;max-width:560px;margin-left:auto;margin-right:auto;font-size:1.1rem;padding:0 1rem}
.steps{list-style:none;display:flex;flex-direction:column;gap:0;max-width:780px;margin:0 auto}
.steps li{display:grid;grid-template-columns:90px 1fr;gap:2.5rem;align-items:start;padding:2.5rem 0 2.75rem;border-bottom:1px solid var(--line-soft);position:relative}
.steps li:last-child{border-bottom:none}
.steps li .numeral{font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:200;font-size:4.5rem;color:var(--copper);line-height:1;letter-spacing:-.02em;text-align:right;padding-top:.35rem;opacity:.85}
.steps li p{font-size:1.08rem;line-height:1.8;color:var(--ink);font-weight:300}
.steps li p em{color:var(--copper-deep);font-style:italic}
.steps li:first-child p::first-letter{font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:300;font-size:4em;float:left;line-height:.85;margin:.08em .12em 0 0;color:var(--copper-deep)}
@media (max-width:640px){.steps li{grid-template-columns:1fr;gap:.5rem;padding:2rem 0 2.25rem}.steps li .numeral{text-align:left;font-size:2.8rem}.steps li:first-child p::first-letter{font-size:3.2em}.steps li p{font-size:1.02rem}}
.books{padding-top:8rem}
.books h2{font-size:clamp(2rem,4.5vw,3.4rem);text-align:center;margin-bottom:5rem;font-weight:300}
.book-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:3rem 2.5rem;perspective:1800px}
.book-3d{text-align:center;transform-style:preserve-3d}
.book-cover{aspect-ratio:3/4.4;margin:0 auto 1.75rem;max-width:220px;width:100%;position:relative;transform:rotateY(-22deg) rotateX(2deg);transform-style:preserve-3d;transition:transform .9s cubic-bezier(.2,.8,.3,1);filter:drop-shadow(8px 18px 28px rgba(45,36,24,.35))}
@media (hover:hover){.book-3d:hover .book-cover{transform:rotateY(-8deg) rotateX(1deg) translateY(-6px)}}
@media (hover:none){.book-cover{transform:rotateY(-12deg) rotateX(2deg)}}
.book-front{position:absolute;inset:0;background:linear-gradient(135deg,var(--copper),var(--copper-deep));border-radius:1px 4px 4px 1px;padding:1.75rem 1.25rem;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}
.book-front::before{content:'';position:absolute;inset:0;background:linear-gradient(115deg,rgba(255,255,255,.12) 0%,transparent 25%,transparent 60%,rgba(0,0,0,.15) 100%);pointer-events:none}
.book-front::after{content:'';position:absolute;top:8%;bottom:8%;left:6px;width:1px;background:rgba(255,255,255,.25)}
.book-spine{position:absolute;top:0;bottom:0;left:0;width:12px;background:linear-gradient(to right,rgba(0,0,0,.45),rgba(0,0,0,.05));transform:translateZ(-2px)}
.book-front .frame{position:absolute;inset:14px;border:1px solid rgba(255,255,255,.18);pointer-events:none}
.book-front .imprint-top{font-family:'Fraunces',Georgia,serif;font-style:italic;font-size:.7rem;letter-spacing:.25em;color:rgba(255,255,255,.55);text-transform:uppercase;text-align:center;position:relative;z-index:1}
.book-front .title{font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:300;color:rgba(255,255,255,.96);font-size:clamp(1.05rem,2.2vw,1.3rem);line-height:1.15;text-align:center;letter-spacing:-.01em;position:relative;z-index:1;padding:0 .25rem;hyphens:auto}
.book-front .imprint-bot{font-family:'Fraunces',Georgia,serif;font-size:.65rem;letter-spacing:.3em;color:rgba(255,255,255,.5);text-transform:uppercase;text-align:center;position:relative;z-index:1}
.book-3d:nth-child(1) .book-front{background:linear-gradient(135deg,var(--oxblood),var(--oxblood-deep))}
.book-3d:nth-child(2) .book-front{background:linear-gradient(135deg,#B27851,#7A4F30)}
.book-3d:nth-child(3) .book-front{background:linear-gradient(135deg,#5C5847,#2F2D24)}
.book-3d:nth-child(4) .book-front{background:linear-gradient(135deg,#8C7752,#5A4A30)}
.book-meta{text-align:center;max-width:240px;margin:0 auto}
.book-meta .lang{font-family:'Fraunces',Georgia,serif;font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--copper);font-style:italic;margin-bottom:.6rem}
.book-meta h3{font-size:1.18rem;line-height:1.25;margin-bottom:.65rem;font-weight:300}
.book-meta p{font-size:.88rem;color:var(--ink-soft);line-height:1.55}
.book-meta .status{margin-top:.8rem;font-size:.78rem;color:var(--copper-deep);font-style:italic;font-family:'Fraunces',Georgia,serif}
.author{background:var(--bg-warm);border-top:1px solid var(--line-soft)}
.author-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:5rem;align-items:center}
@media (max-width:880px){.author-grid{grid-template-columns:1fr;gap:3.5rem}}
.author-portrait{aspect-ratio:4/5;width:100%;max-width:380px;margin:0 auto;background:linear-gradient(165deg,var(--copper-deep) 0%,var(--bg-deep) 100%);position:relative;overflow:hidden;box-shadow:0 30px 60px -20px rgba(45,36,24,.45)}
.author-portrait::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 32% 24%,rgba(255,235,200,.18),transparent 55%)}
.author-portrait::after{content:'';position:absolute;inset:16px;border:1px solid rgba(255,235,200,.22)}
.author-portrait .frame-inner{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:space-between;padding:2rem 1.75rem}
.author-portrait .top-mark,.author-portrait .bot-mark{font-family:'Fraunces',Georgia,serif;font-size:.7rem;letter-spacing:.32em;color:rgba(255,235,200,.55);text-transform:uppercase;text-align:center}
.author-portrait .top-mark{font-style:italic;color:rgba(255,235,200,.6)}
.author-portrait .initials{font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:200;font-size:clamp(4rem,12vw,5.5rem);color:rgba(255,240,215,.95);line-height:1;text-align:center;letter-spacing:-.02em}
.author h2{font-size:clamp(2rem,4vw,3rem);margin-bottom:2.5rem;font-weight:300}
.author p{font-size:1.02rem;color:var(--ink-soft);line-height:1.85;margin-bottom:1.4rem}
.author p:last-child{margin-bottom:0}
.author p strong{color:var(--ink);font-weight:400}
.author p em{color:var(--copper-deep);font-style:italic}
footer.site{background:var(--bg-deep);color:var(--bg);padding:6rem 2rem 2.5rem;padding-bottom:calc(2.5rem + var(--safe-bottom));position:relative;overflow:hidden;z-index:2}
footer.site::before{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='nf'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.92 0 0 0 0 0.82 0 0 0 0 0.62 0 0 0 0.35 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23nf)'/%3E%3C/svg%3E");opacity:.14;mix-blend-mode:overlay;pointer-events:none}
footer.site .container{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:4rem;margin-bottom:5rem;position:relative}
@media (max-width:900px){footer.site .container{grid-template-columns:1fr 1fr;gap:3rem}footer.site .container > div:first-child{grid-column:1 / -1}}
@media (max-width:560px){footer.site .container{grid-template-columns:1fr;gap:2.5rem}}
footer.site h3{color:var(--bg);font-size:clamp(1.55rem,3vw,2rem);margin-bottom:1.5rem;font-weight:200;line-height:1.2}
footer.site .label{font-size:.74rem;letter-spacing:.32em;color:var(--copper-soft);margin-bottom:1.5rem}
footer.site .label::before{background:var(--copper)}
footer.site p{color:rgba(236,226,204,.72);line-height:1.8;margin-bottom:.5rem;font-size:.95rem}
footer.site a{color:var(--bg);text-decoration:none;border-bottom:1px solid rgba(236,226,204,.25);transition:border-color .25s,color .25s}
@media (hover:hover){footer.site a:hover{border-bottom-color:var(--copper);color:var(--copper-soft)}footer.site ul a:hover{color:var(--copper-soft);border-bottom:none}}
footer.site ul{list-style:none}
footer.site ul li{margin-bottom:.65rem}
footer.site ul a{border-bottom:none;color:rgba(236,226,204,.72);font-size:.92rem}
.imprint{border-top:1px solid rgba(236,226,204,.15);padding-top:2rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.8rem;color:rgba(236,226,204,.42);max-width:1180px;margin:0 auto;position:relative;font-family:'Fraunces',Georgia,serif;font-style:italic}
.imprint .legal-links{display:flex;gap:1.25rem}
.imprint .legal-links a{color:rgba(236,226,204,.55);text-decoration:none;border-bottom:1px solid transparent;transition:color .25s,border-color .25s}
.imprint .legal-links a:hover{color:var(--copper-soft);border-bottom-color:var(--copper)}
.sound-toggle{position:fixed;bottom:calc(1.5rem + var(--safe-bottom));right:calc(1.5rem + env(safe-area-inset-right,0px));z-index:50;width:48px;height:48px;border-radius:50%;background:var(--bg-card);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;color:var(--ink-soft);box-shadow:0 4px 16px rgba(45,36,24,.08);-webkit-tap-highlight-color:transparent}
@media (hover:hover){.sound-toggle:hover{background:var(--copper);color:var(--bg);border-color:var(--copper-deep);transform:scale(1.05)}.sound-toggle:hover .sound-tooltip{opacity:1}}
.sound-toggle.active{background:var(--copper-deep);color:var(--bg);border-color:var(--copper-deep)}
.sound-toggle .bars{display:flex;align-items:center;gap:2px;height:14px}
.sound-toggle .bars span{display:block;width:2px;background:currentColor;border-radius:1px}
.sound-toggle .bars span:nth-child(1){height:50%}.sound-toggle .bars span:nth-child(2){height:100%}.sound-toggle .bars span:nth-child(3){height:70%}.sound-toggle .bars span:nth-child(4){height:40%}
.sound-toggle.active .bars span{animation:bar 1.4s ease-in-out infinite}
.sound-toggle.active .bars span:nth-child(2){animation-delay:.1s}.sound-toggle.active .bars span:nth-child(3){animation-delay:.2s}.sound-toggle.active .bars span:nth-child(4){animation-delay:.3s}
@keyframes bar{0%,100%{transform:scaleY(.5)}50%{transform:scaleY(1)}}
.sound-tooltip{position:absolute;right:calc(100% + 12px);top:50%;transform:translateY(-50%);background:var(--bg-deep);color:var(--bg);padding:.5rem .8rem;font-family:'Fraunces',Georgia,serif;font-style:italic;font-size:.78rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .25s}
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1.1s,transform 1.1s}
.reveal.visible{opacity:1;transform:translateY(0)}
@media (max-width:600px){section{padding:4.5rem 1.25rem}.books{padding-top:5rem}nav.top{padding:1rem 1.25rem;padding-top:calc(1rem + var(--safe-top))}nav.top.scrolled{padding:.8rem 1.25rem;padding-top:calc(.8rem + var(--safe-top))}.pull-quote{padding:5rem 1.25rem}.label{font-size:.72rem;letter-spacing:.28em}.label::before{width:24px}}
@media (max-width:380px){section{padding:4rem 1rem}.pull-quote{padding:4.5rem 1rem}}
.legal-page{padding:2rem 1.5rem;min-height:100vh}
.legal-page nav.simple{max-width:740px;margin:0 auto 4rem;padding:1.5rem 0;border-bottom:1px solid var(--line);position:relative;z-index:2}
.legal-page nav.simple a.brand{font-family:'Fraunces',Georgia,serif;color:var(--ink);text-decoration:none;font-size:1.05rem;font-weight:400;display:inline-flex;align-items:center}
.legal-page main{max-width:740px;margin:0 auto;padding:0 0 3rem;position:relative;z-index:2}
.legal-page h1{font-family:'Fraunces',Georgia,serif;font-weight:200;font-size:clamp(2.2rem,5vw,3.5rem);line-height:1.05;letter-spacing:-.02em;margin-bottom:1.25rem}
.legal-page .brief-en{color:var(--ink-soft);font-style:italic;font-family:'Fraunces',Georgia,serif;margin-bottom:3.5rem;padding-bottom:2rem;border-bottom:1px solid var(--line-soft);font-size:1rem}
.legal-page h2{font-family:'Fraunces',Georgia,serif;font-weight:300;font-size:1.35rem;margin-top:3rem;margin-bottom:1rem;color:var(--copper-deep);letter-spacing:-.01em}
.legal-page h2:first-of-type{margin-top:0}
.legal-page p{margin-bottom:1rem;color:var(--ink-soft)}
.legal-page ul{margin:0 0 1rem 1.5rem;color:var(--ink-soft)}
.legal-page li{margin-bottom:.4rem}
.legal-page strong{color:var(--ink);font-weight:400}
.legal-page a{color:var(--copper-deep);text-decoration:none;border-bottom:1px solid rgba(139,90,56,.3);transition:border-color .25s}
.legal-page a:hover{border-bottom-color:var(--copper-deep)}
.legal-page .placeholder{color:var(--ink-muted);font-style:italic;background:var(--bg-warm);padding:.1em .4em;border-radius:2px}
.legal-page .date{font-family:'Fraunces',Georgia,serif;font-style:italic;color:var(--ink-muted);font-size:.9rem;margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--line-soft)}
.legal-page footer.simple{max-width:740px;margin:4rem auto 0;padding:2rem 0;border-top:1px solid var(--line);font-family:'Fraunces',Georgia,serif;font-style:italic;font-size:.85rem;color:var(--ink-muted);text-align:center;position:relative;z-index:2}
.legal-page footer.simple a{color:var(--ink-muted);border-bottom:1px solid transparent}
.legal-page footer.simple a:hover{color:var(--copper-deep);border-bottom-color:var(--copper)}
.legal-page footer.simple .links{display:flex;gap:1.5rem;justify-content:center;margin-bottom:1rem;flex-wrap:wrap}
.page-404{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;text-align:center;padding:2rem}
.page-404 .numeral{font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:200;font-size:clamp(7rem,20vw,12rem);line-height:1;color:var(--copper);margin-bottom:1.5rem;letter-spacing:-.04em}
.page-404 h1{font-family:'Fraunces',Georgia,serif;font-weight:300;font-size:clamp(1.5rem,4vw,2.2rem);margin-bottom:1.5rem;letter-spacing:-.015em}
.page-404 p{font-family:'Fraunces',Georgia,serif;font-style:italic;color:var(--ink-soft);margin-bottom:.75rem;font-size:1.05rem}
.page-404 .divider{margin:2.5rem auto;width:48px;height:1px;background:var(--copper)}
.page-404 .back{display:inline-block;margin-top:1rem;font-family:'Fraunces',Georgia,serif;font-style:italic;color:var(--copper-deep);text-decoration:none;border-bottom:1px solid rgba(139,90,56,.3);padding-bottom:.15rem;transition:border-color .25s}
.page-404 .back:hover{border-bottom-color:var(--copper-deep)}