
:root{
  --paper:#FBF7F0; --paper-2:#F4ECDE; --ink:#241C17; --ink-soft:#5A4F45;
  --tinto:#7A2B2B; --tinto-d:#5E1F1F; --azafran:#C8862A; --azafran-d:#A86A18;
  --oliva:#5E6B3A; --line:#E4D8C5; --line-2:#D8C7AC; --card:#FFFDF9;
  --maxw:1140px; --r:14px;
  --shadow:0 1px 2px rgba(36,28,23,.05), 0 8px 28px -16px rgba(36,28,23,.18);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:18px; line-height:1.65; -webkit-font-smoothing:antialiased;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 22px}
h1,h2,h3,h4{font-family:"Playfair Display",Georgia,"Times New Roman",serif; font-weight:700; line-height:1.12; letter-spacing:-.01em; margin:0}
.serif{font-family:"Playfair Display",Georgia,serif}
.mono{font-family:"Inter",sans-serif; font-variant-numeric:tabular-nums}

/* ---- labels / kicker ---- */
.kick{font-size:12px; letter-spacing:.16em; text-transform:uppercase; font-weight:600; color:var(--azafran-d)}
.kick a{color:inherit}
.tick{display:inline-block; width:7px; height:7px; background:var(--azafran); transform:rotate(45deg); margin-right:8px; vertical-align:middle}

/* ---- top bar + masthead ---- */
.topbar{background:var(--tinto); color:#F6E7D8; font-size:11.5px; letter-spacing:.14em; text-transform:uppercase}
.topbar .wrap{display:flex; justify-content:space-between; align-items:center; height:34px}
.topbar a{color:#F6E7D8; opacity:.85}
.topbar a:hover{opacity:1}
.masthead{border-bottom:1px solid var(--line); background:var(--paper)}
.masthead .wrap{display:flex; align-items:center; justify-content:space-between; gap:18px; padding-top:20px; padding-bottom:14px}
.brand{display:flex; align-items:center; gap:13px}
.brand .word{font-family:"Playfair Display",serif; font-weight:800; font-size:30px; letter-spacing:-.02em; color:var(--ink)}
.brand .sub{font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft); margin-top:2px}
.btn{display:inline-block; background:var(--tinto); color:#FFF7EE; padding:10px 16px; border-radius:999px; font-size:13.5px; font-weight:600; letter-spacing:.02em; border:1px solid var(--tinto-d)}
.btn:hover{background:var(--tinto-d)}
.btn.ghost{background:transparent; color:var(--tinto); border-color:var(--line-2)}
.btn.ghost:hover{background:var(--paper-2)}

/* measure rule under masthead */
.rule{height:0; border-top:2px solid var(--ink); position:relative; max-width:var(--maxw); margin:0 auto}
.rule:before,.rule:after{content:""; position:absolute; top:-2px; width:46px; height:2px; background:var(--azafran)}
.rule:before{left:0} .rule:after{right:0}

/* ---- nav ---- */
nav.main{border-bottom:1px solid var(--line); background:var(--paper); position:sticky; top:0; z-index:30}
nav.main .wrap{display:flex; gap:4px; flex-wrap:wrap; align-items:center; min-height:50px}
nav.main a{font-size:14.5px; font-weight:500; color:var(--ink-soft); padding:14px 12px; border-bottom:2px solid transparent}
nav.main a:hover{color:var(--ink)}
nav.main a.active{color:var(--tinto); border-bottom-color:var(--azafran)}
nav.main .spacer{flex:1}
nav.main .small{font-size:13px}

/* ---- photo frame (graceful fallback) ---- */
.ph{position:relative; margin:0; overflow:hidden; border-radius:var(--r); background:
  linear-gradient(135deg,#EFE2CC,#E7D2B6 60%,#E0C7A0);
  border:1px solid var(--line-2)}
.ph img{width:100%; height:100%; object-fit:cover; display:block}
.ph.r43{aspect-ratio:4/3}
.ph.r169{aspect-ratio:16/9}
.ph.r11{aspect-ratio:1/1}
.ph.r32{aspect-ratio:3/2}
figure.fig{margin:30px 0}
figure.fig figcaption{font-size:13px; color:var(--ink-soft); margin-top:9px; padding-left:2px}
figcaption .cr{color:var(--line-2)}

/* ---- hero ---- */
.hero{padding:40px 0 30px}
.hero .grid{display:grid; grid-template-columns:1.05fr 1fr; gap:40px; align-items:center}
.hero h1{font-size:clamp(34px,4.4vw,56px); margin:14px 0 0}
.hero .dek{font-size:19px; color:var(--ink-soft); margin:18px 0 22px; max-width:34ch}
.byline{display:flex; align-items:center; gap:11px; font-size:13.5px; color:var(--ink-soft)}
.avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:13px;color:#fff; font-family:"Inter",sans-serif; flex:none}
.dot{width:3px;height:3px;border-radius:50%;background:var(--line-2);display:inline-block}

/* ---- section heads ---- */
.sec{margin:54px 0 0}
.sec-h{display:flex; align-items:baseline; justify-content:space-between; border-bottom:1px solid var(--line); padding-bottom:12px; margin-bottom:26px}
.sec-h h2{font-size:25px}
.sec-h .more{font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--azafran-d); font-weight:600}

/* ---- cards ---- */
.cards{display:grid; grid-template-columns:repeat(3,1fr); gap:30px 28px}
.cards.c2{grid-template-columns:repeat(2,1fr)}
.card .ph{margin-bottom:13px}
.card h3{font-size:20px; line-height:1.2; margin:4px 0 0}
.card .dek{font-size:14.5px; color:var(--ink-soft); margin:8px 0 0}
.card .meta{font-size:12px; color:var(--ink-soft); margin-top:11px; display:flex; gap:10px; align-items:center; flex-wrap:wrap}
.card a.h{color:inherit}
.card a.h:hover h3{color:var(--tinto)}

/* feature row */
.feature{display:grid; grid-template-columns:1.25fr 1fr; gap:34px; align-items:center}
.feature .ph{margin:0}
.feature h2{font-size:30px; margin:10px 0 0}
.feature .dek{font-size:16.5px; color:var(--ink-soft); margin-top:12px}

/* list rows */
.rows{display:flex; flex-direction:column}
.row{display:grid; grid-template-columns:128px 1fr auto; gap:20px; padding:20px 0; border-bottom:1px solid var(--line); align-items:center}
.row .ph{margin:0}
.row h3{font-size:18.5px; margin:0}
.row .dek{font-size:14px; color:var(--ink-soft); margin:6px 0 0}
.row .rt{font-size:12px; color:var(--ink-soft); white-space:nowrap; text-align:right}

/* category tiles */
.tiles{display:grid; grid-template-columns:repeat(3,1fr); gap:26px}
.tile{display:block; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:var(--card); box-shadow:var(--shadow)}
.tile .ph{border:0; border-radius:0}
.tile .ph.r169{aspect-ratio:16/10}
.tile .b{padding:16px 17px 18px}
.tile h3{font-size:19px}
.tile p{font-size:14px; color:var(--ink-soft); margin:7px 0 0}
.tile .n{font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--azafran-d); font-weight:600; margin-top:11px}
.tile:hover h3{color:var(--tinto)}

/* ---- newsletter ---- */
.news{background:var(--tinto); color:#F8ECDD; border-radius:18px; padding:38px 40px; margin:60px 0 0; display:grid; grid-template-columns:1.3fr 1fr; gap:34px; align-items:center}
.news h2{color:#FFF7EE; font-size:27px}
.news p{color:#EED9C5; margin:12px 0 0; font-size:15.5px}
.news .form{display:flex; gap:9px; margin-top:8px}
.news input{flex:1; padding:13px 15px; border-radius:10px; border:1px solid rgba(255,255,255,.25); background:rgba(255,255,255,.08); color:#fff; font-size:15px}
.news input::placeholder{color:#E7CFB6}
.news .btn{background:var(--azafran); border-color:var(--azafran-d); color:#3A2410}
.news .btn:hover{background:var(--azafran-d); color:#fff}
.news .stats{display:flex; gap:26px; margin-top:18px}
.news .stats b{font-family:"Playfair Display",serif; font-size:24px; color:#FFF7EE; display:block}
.news .stats span{font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; color:#E7CFB6}
.news .fine{font-size:12px; color:#D9BFA6; margin-top:12px}

/* ---- article / recipe ---- */
.article{max-width:760px; margin:0 auto; padding:38px 0 10px}
.article .head{max-width:760px; margin:0 auto}
.article h1{font-size:clamp(30px,4vw,46px); margin:14px 0 0}
.article .dek{font-size:19.5px; color:var(--ink-soft); margin:16px 0 20px; line-height:1.5}
.article .byrow{display:flex; align-items:center; gap:12px; padding:14px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); font-size:14px; color:var(--ink-soft); flex-wrap:wrap}
.article .byrow b{color:var(--ink)}
.prose{font-size:18.5px; line-height:1.74}
.prose p{margin:22px 0}
.prose h2{font-size:27px; margin:42px 0 0}
.prose h3{font-size:21px; margin:32px 0 0}
.prose ul,.prose ol{margin:20px 0; padding-left:24px}
.prose li{margin:9px 0}
.prose blockquote{margin:30px 0; padding:6px 0 6px 22px; border-left:3px solid var(--azafran); font-family:"Playfair Display",serif; font-size:22px; font-style:italic; color:var(--tinto)}
.prose a{color:var(--tinto); text-decoration:underline; text-underline-offset:2px; text-decoration-color:var(--line-2)}

/* recipe ficha card */
.ficha{display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line-2); border-radius:var(--r); overflow:hidden; margin:28px 0; background:var(--card)}
.ficha div{padding:15px 16px; border-right:1px solid var(--line)}
.ficha div:last-child{border-right:0}
.ficha .k{font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--azafran-d); font-weight:600}
.ficha .v{font-family:"Playfair Display",serif; font-size:20px; margin-top:4px}

/* ingredients + steps blocks */
.cook{display:grid; grid-template-columns:300px 1fr; gap:40px; margin:30px 0; align-items:start}
.ing{background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r); padding:20px 22px; position:sticky; top:66px}
.ing h3{font-size:18px; margin:0 0 6px}
.ing ul{list-style:none; margin:12px 0 0; padding:0}
.ing li{padding:9px 0; border-bottom:1px dashed var(--line-2); font-size:15.5px; display:flex; justify-content:space-between; gap:12px}
.ing li:last-child{border-bottom:0}
.ing li .q{color:var(--tinto); font-weight:600; white-space:nowrap; font-variant-numeric:tabular-nums}
.steps{counter-reset:s}
.steps h3{font-size:20px; margin:0 0 6px}
.steps ol{list-style:none; padding:0; margin:14px 0 0}
.steps li{position:relative; padding:4px 0 22px 52px; margin:0}
.steps li:before{counter-increment:s; content:counter(s); position:absolute; left:0; top:0; width:34px; height:34px; border-radius:50%; background:var(--tinto); color:#FFF3E6; font-family:"Playfair Display",serif; font-weight:700; display:grid; place-items:center; font-size:16px}
.steps li:after{content:""; position:absolute; left:16px; top:36px; bottom:6px; width:2px; background:var(--line-2)}
.steps li:last-child:after{display:none}
.steps li p{margin:0 0 0 0; font-size:16.5px; line-height:1.6}
.steps li b{color:var(--tinto)}

/* callouts */
.note{background:var(--paper-2); border:1px solid var(--line); border-left:3px solid var(--oliva); border-radius:10px; padding:16px 18px; margin:26px 0; font-size:15.5px}
.note .t{font-size:11px; letter-spacing:.13em; text-transform:uppercase; color:var(--oliva); font-weight:700; margin-bottom:6px}

/* author bio box */
.bio{display:flex; gap:16px; align-items:flex-start; border:1px solid var(--line); border-radius:var(--r); padding:18px 20px; margin:34px 0; background:var(--card)}
.bio .avatar{width:54px;height:54px;font-size:18px}
.bio h4{font-size:17px}
.bio .role{font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--azafran-d); font-weight:600; margin:3px 0 7px}
.bio p{font-size:14.5px; color:var(--ink-soft); margin:0}

/* page intro (static) */
.pintro{max-width:760px; margin:0 auto; padding:46px 0 8px}
.pintro h1{font-size:clamp(30px,4vw,44px)}
.pintro .lead{font-size:20px; color:var(--ink-soft); margin-top:16px; line-height:1.5}

/* team grid */
.team{display:grid; grid-template-columns:repeat(2,1fr); gap:22px; margin-top:30px}
.member{display:flex; gap:15px; border:1px solid var(--line); border-radius:var(--r); padding:18px; background:var(--card)}
.member .avatar{width:58px;height:58px;font-size:19px}
.member h3{font-size:18px}
.member .role{font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--azafran-d); font-weight:600; margin:3px 0 7px}
.member p{font-size:13.5px; color:var(--ink-soft); margin:0}

/* contact + form */
.cols2{display:grid; grid-template-columns:1fr 1fr; gap:34px; margin-top:14px}
.fld{margin:14px 0}
.fld label{font-size:13px; font-weight:600; display:block; margin-bottom:6px}
.fld input,.fld textarea{width:100%; padding:12px 14px; border:1px solid var(--line-2); border-radius:10px; background:var(--card); font:inherit; font-size:15px}
.deptbox{border:1px solid var(--line); border-radius:var(--r); padding:6px 18px; background:var(--card)}
.deptbox .d{display:flex; justify-content:space-between; padding:13px 0; border-bottom:1px solid var(--line); font-size:14.5px}
.deptbox .d:last-child{border-bottom:0}
.deptbox .d span{color:var(--ink-soft)}
.deptbox .d a{color:var(--tinto)}

/* related */
.related{margin:50px 0 0; border-top:1px solid var(--line); padding-top:26px}

/* footer */
footer{background:#2B211B; color:#E7D8C7; margin-top:72px; padding:48px 0 30px}
footer .grid{display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:30px}
footer .word{font-family:"Playfair Display",serif; font-weight:800; font-size:23px; color:#FBF1E4}
footer p{font-size:13.5px; color:#BBA793; margin:12px 0 0; max-width:34ch}
footer h5{font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:#C8A983; margin:0 0 12px}
footer ul{list-style:none; padding:0; margin:0}
footer li{margin:8px 0}
footer a{font-size:14px; color:#E0CFBC}
footer a:hover{color:#fff}
footer .bottom{border-top:1px solid #44362C; margin-top:34px; padding-top:18px; display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; font-size:12.5px; color:#A8957F}

/* tag chip */
.chip{display:inline-block; font-size:11px; letter-spacing:.1em; text-transform:uppercase; font-weight:600; color:var(--tinto); background:var(--paper-2); border:1px solid var(--line-2); padding:3px 9px; border-radius:999px}

/* responsive */
@media(max-width:900px){
  .hero .grid,.feature,.news,.cook,.cols2,.team{grid-template-columns:1fr}
  .cards,.tiles{grid-template-columns:repeat(2,1fr)}
  .ficha{grid-template-columns:repeat(2,1fr)}
  .ficha div:nth-child(2){border-right:0}
  .ing{position:static}
  footer .grid{grid-template-columns:1fr 1fr}
  .hero .ph{order:-1}
}
@media(max-width:560px){
  body{font-size:17px}
  .cards,.tiles{grid-template-columns:1fr}
  .row{grid-template-columns:84px 1fr; }
  .row .rt{display:none}
  .ficha{grid-template-columns:1fr 1fr}
  footer .grid{grid-template-columns:1fr}
  .brand .sub{display:none}
}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important}}
a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--azafran); outline-offset:2px}
