/* Maria Laverghetta — site styles */
:root{
  --ink:#1a1714;--paper:#f4efe6;--paper-deep:#ebe3d5;--cream:#e8d9a8;
  --accent:#b8893f;--accent-deep:#8f6526;--line:rgba(26,23,20,0.12);--muted:#6b6259;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:'Newsreader',Georgia,serif;font-size:19px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:0.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.wrap{max-width:1180px;margin:0 auto;padding:0 40px;position:relative;z-index:2}
@media(max-width:560px){.wrap{padding:0 24px}}

/* NAV */
nav{display:flex;justify-content:space-between;align-items:center;padding:34px 0 0}
.logo{font-family:'Fraunces',serif;font-weight:600;font-size:21px;letter-spacing:-0.01em;text-decoration:none;color:var(--ink);white-space:nowrap}
.logo span{color:var(--accent)}
.navlinks{display:flex;gap:34px;font-size:15px;letter-spacing:0.02em}
.navlinks a{color:var(--ink);text-decoration:none;opacity:0.75;transition:opacity .25s}
.navlinks a:hover{opacity:1;color:var(--accent-deep)}
@media(max-width:760px){.navlinks{gap:20px;font-size:14px}}
@media(max-width:560px){nav{flex-wrap:wrap;gap:14px;padding-top:24px}.logo{font-size:19px}.navlinks{gap:16px;font-size:13px}}

/* HERO */
.hero{display:grid;grid-template-columns:1.35fr 1fr;gap:70px;align-items:center;padding:90px 0 110px}
.hero-eyebrow{font-size:14px;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:28px;opacity:0;animation:rise .9s .1s forwards}
.hero h1{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(46px,6.4vw,86px);line-height:0.98;letter-spacing:-0.025em;margin-bottom:30px}
.hero h1 .l2{display:block;font-style:italic;font-weight:400;color:var(--accent-deep)}
.hero h1 span{opacity:0;display:inline-block;animation:rise .9s forwards}
.hero p{font-size:21px;color:var(--muted);max-width:30em;margin-bottom:38px;opacity:0;animation:rise .9s .7s forwards}
.hero .cta{display:flex;gap:18px;align-items:center;flex-wrap:wrap;opacity:0;animation:rise .9s .85s forwards}
.btn{font-family:'Newsreader',serif;font-size:17px;text-decoration:none;padding:13px 28px;border-radius:2px;transition:all .25s;letter-spacing:0.01em;cursor:pointer}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--accent-deep)}
.btn-ghost{color:var(--ink);border-bottom:1.5px solid var(--accent);padding:13px 4px;border-radius:0}
.btn-ghost:hover{color:var(--accent-deep)}
.portrait-frame{position:relative;opacity:0;animation:rise 1.1s .4s forwards}
.portrait-frame::before{content:"";position:absolute;inset:18px -18px -18px 18px;border:1.5px solid var(--accent);border-radius:3px;z-index:0}
.portrait-frame img{width:100%;display:block;border-radius:3px;position:relative;z-index:1;filter:grayscale(0.12) contrast(1.02);box-shadow:0 30px 60px -25px rgba(26,23,20,0.4)}
@media(max-width:860px){.hero{grid-template-columns:1fr;gap:50px;padding:60px 24px 80px}.portrait-frame{max-width:380px}}

/* STRIP */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:26px 0;overflow:hidden;white-space:nowrap}
.strip-inner{display:flex;width:max-content;animation:slide 50s linear infinite;font-family:'Fraunces',serif;font-size:17px;letter-spacing:0.04em;will-change:transform}
.strip-set{display:flex;flex:none}
.strip-inner span{color:var(--muted);padding-right:60px;flex:none;white-space:nowrap}
.strip-inner span b{color:var(--accent-deep);font-weight:600}
@keyframes slide{to{transform:translateX(-50%)}}
.strip:hover .strip-inner{animation-play-state:paused}
@media(prefers-reduced-motion:reduce){.strip-inner{animation:none;transform:none}}

/* SECTIONS */
.sec{padding:100px 0}
.sec-label{font-size:13px;letter-spacing:0.24em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:18px}
.sec h2{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(32px,4vw,52px);line-height:1.05;letter-spacing:-0.02em;margin-bottom:50px;max-width:16em}
.sec h2 em{font-style:italic;color:var(--accent-deep);font-weight:400}

/* ABOUT */
.about{display:grid;grid-template-columns:1fr 1.2fr;gap:70px;align-items:start}
.about .lede{font-size:24px;line-height:1.5;font-style:italic;color:var(--ink)}
.about p{margin-bottom:22px;color:#34302a}
.about .pillars{margin-top:36px;display:flex;flex-direction:column;gap:0}
.pillar{padding:20px 0;border-top:1px solid var(--line);display:flex;gap:20px;align-items:baseline}
.pillar .n{font-family:'Fraunces',serif;color:var(--accent);font-size:15px;min-width:34px}
.pillar .t{font-family:'Fraunces',serif;font-size:20px;font-weight:500}
@media(max-width:860px){.about{grid-template-columns:1fr;gap:30px}}

/* WRITING INDEX */
.writing{background:var(--paper-deep);margin:0 -9999px;padding:100px 9999px}
.posts{display:grid;gap:0}
.post{display:grid;grid-template-columns:120px 1fr auto;gap:40px;align-items:baseline;padding:34px 0;border-top:1px solid var(--line);text-decoration:none;color:var(--ink);transition:padding-left .3s ease;position:relative}
.post:last-child{border-bottom:1px solid var(--line)}
.post:hover{padding-left:20px}
.post:hover .post-title{color:var(--accent-deep)}
.post:hover .arrow{opacity:1;transform:translateX(0)}
.post .date{font-size:14px;color:var(--muted);letter-spacing:0.03em;padding-top:6px}
.post .cat{font-size:12px;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:8px}
.post-title{font-family:'Fraunces',serif;font-size:clamp(22px,2.4vw,30px);font-weight:500;line-height:1.15;transition:color .25s;max-width:18em}
.arrow{font-size:24px;opacity:0;transform:translateX(-8px);transition:all .3s;color:var(--accent)}
@media(max-width:680px){.post{grid-template-columns:1fr;gap:8px}.post .arrow{display:none}.post .date{padding-top:0;order:2}}

/* RESOURCES */
.res-intro{max-width:34em;font-size:21px;color:#34302a;margin-bottom:56px}
.res-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.res-card{border:1px solid var(--line);border-radius:3px;padding:38px 34px;background:rgba(255,255,255,0.35);transition:transform .3s, box-shadow .3s, border-color .3s}
.res-card:hover{transform:translateY(-4px);box-shadow:0 24px 44px -28px rgba(26,23,20,0.45);border-color:var(--accent)}
.res-card .rc-num{font-family:'Fraunces',serif;font-size:14px;color:var(--accent);letter-spacing:0.1em;margin-bottom:14px}
.res-card h3{font-family:'Fraunces',serif;font-weight:600;font-size:25px;letter-spacing:-0.01em;margin-bottom:14px}
.res-card p{font-size:17px;color:var(--muted);margin-bottom:22px;line-height:1.55}
.res-list{list-style:none;display:flex;flex-direction:column;gap:0}
.res-list li{padding:13px 0;border-top:1px dashed var(--line);font-size:16px;display:flex;justify-content:space-between;align-items:baseline;gap:14px}
.res-list li .tool{font-family:'Fraunces',serif;font-weight:500}
.res-list li .tag{font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent-deep);white-space:nowrap}
.res-note{margin-top:50px;font-style:italic;color:var(--muted);font-size:18px;max-width:38em}
@media(max-width:760px){.res-grid{grid-template-columns:1fr}}

/* CLEARANCE BLOCK */
.clear-block{margin-top:80px;border:1px solid var(--line);border-radius:3px;padding:50px 48px;background:rgba(255,255,255,0.4)}
.clear-block .cb-label{font-size:13px;letter-spacing:0.2em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:16px}
.clear-block h3{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(26px,3vw,36px);letter-spacing:-0.01em;margin-bottom:20px;line-height:1.1}
.clear-block .cb-intro{font-size:20px;color:#2c2823;margin-bottom:14px;line-height:1.55}
.clear-block .cb-intro:last-of-type{margin-bottom:36px}
.clear-block h4{font-family:'Fraunces',serif;font-weight:600;font-size:19px;margin:34px 0 16px;color:var(--ink)}
.cb-points{list-style:none;display:flex;flex-direction:column;gap:0}
.cb-points li{padding:16px 0 16px 28px;border-top:1px solid var(--line);position:relative;color:#2c2823;font-size:17px;line-height:1.5}
.cb-points li::before{content:"";position:absolute;left:0;top:25px;width:12px;height:1.5px;background:var(--accent)}
.cb-obj{display:flex;flex-direction:column;gap:0;margin-top:6px}
.cb-obj .row{padding:18px 0;border-top:1px solid var(--line)}
.cb-obj .q{font-family:'Fraunces',serif;font-weight:500;font-size:17px;color:var(--ink);margin-bottom:6px}
.cb-obj .q::before{content:"\201C";color:var(--accent)}
.cb-obj .q::after{content:"\201D";color:var(--accent)}
.cb-obj .a{font-size:16px;color:var(--muted);line-height:1.55}
.cb-obj .a strong{color:var(--ink);font-weight:600;font-style:normal}
.cb-summary{margin-top:36px;padding:26px 30px;background:var(--paper-deep);border-left:2px solid var(--accent);font-size:16px;color:#2c2823;line-height:1.6}
.cb-summary .lbl{display:block;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:10px}
@media(max-width:760px){.clear-block{padding:36px 26px}}

/* QUOTE */
.quote{text-align:center;max-width:24em;margin:0 auto}
.quote p{font-family:'Fraunces',serif;font-style:italic;font-weight:400;font-size:clamp(26px,3.4vw,42px);line-height:1.25;letter-spacing:-0.01em}
.quote .by{font-size:14px;letter-spacing:0.2em;text-transform:uppercase;color:var(--accent-deep);margin-top:30px}

/* CONTACT */
.contact{padding:120px 0 60px}
.contact .c-head{text-align:center;max-width:16em;margin:0 auto 64px}
.c-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.c-card{border-top:2px solid var(--accent);padding:30px 0 0;display:flex;flex-direction:column}
.c-card .ico{font-family:'Fraunces',serif;font-size:14px;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:14px}
.c-card h3{font-family:'Fraunces',serif;font-weight:600;font-size:23px;margin-bottom:12px}
.c-card p{font-size:16px;color:var(--muted);margin-bottom:20px;flex-grow:1;line-height:1.55}
.c-card a{font-size:16px;color:var(--ink);text-decoration:none;border-bottom:1.5px solid var(--accent);padding-bottom:2px;align-self:flex-start;transition:color .25s}
.c-card a:hover{color:var(--accent-deep)}
@media(max-width:760px){.c-grid{grid-template-columns:1fr;gap:44px}}

footer{border-top:1px solid var(--line);padding:34px 0;display:flex;justify-content:space-between;font-size:14px;color:var(--muted);flex-wrap:wrap;gap:12px;margin-top:60px}
footer a{color:var(--muted);text-decoration:none;border-bottom:1px solid var(--line)}
footer a:hover{color:var(--accent-deep)}

/* ARTICLE PAGE */
.article{max-width:720px;margin:0 auto;padding:70px 0 40px}
.article .back{font-size:14px;letter-spacing:0.04em;color:var(--muted);text-decoration:none;display:inline-block;margin-bottom:50px;transition:color .25s}
.article .back:hover{color:var(--accent-deep)}
.article .a-cat{font-size:13px;letter-spacing:0.2em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:16px}
.article h1{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(34px,5vw,56px);line-height:1.04;letter-spacing:-0.02em;margin-bottom:22px}
.article .a-date{font-size:15px;color:var(--muted);margin-bottom:50px;padding-bottom:40px;border-bottom:1px solid var(--line)}
.article p{margin-bottom:26px;color:#2c2823;font-size:20px}
.article h2{font-family:'Fraunces',serif;font-weight:600;font-size:30px;letter-spacing:-0.01em;margin:46px 0 20px}
.article ul{margin:0 0 26px 0;padding-left:0;list-style:none}
.article ul li{padding:10px 0 10px 28px;position:relative;color:#2c2823;font-size:19px}
.article ul li::before{content:"";position:absolute;left:0;top:19px;width:10px;height:1.5px;background:var(--accent)}
.article ol{margin:0 0 26px 1.2em;color:#2c2823}
.article ol li{padding:6px 0;font-size:19px}
.article .a-note{margin-top:50px;padding:26px 30px;background:rgba(255,255,255,0.4);border-left:2px solid var(--accent);font-size:16px;font-style:italic;color:var(--muted)}
.article .a-foot{margin-top:70px;padding-top:40px;border-top:1px solid var(--line);display:flex;align-items:center;gap:20px}
.article .a-foot img{width:64px;height:64px;border-radius:50%;object-fit:cover}
.article .a-foot .who{font-family:'Fraunces',serif;font-weight:600;font-size:18px}
.article .a-foot .role{font-size:14px;color:var(--muted)}

@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:translateY(0)}
