/* Brindari — page-specific styles for Products, Quality, Shipping, Contact, Insights */

/* ---------- Quality: cert grid ---------- */
.cert-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media (max-width:960px){ .cert-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .cert-grid{ grid-template-columns:1fr; } }
.cert{ background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:28px; display:flex; flex-direction:column; gap:14px; transition:transform 200ms,box-shadow 200ms; }
.cert:hover{ transform:translateY(-2px); box-shadow:var(--shadow-soft); }
.cert-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:14px; }
.cert-mark{ width:64px; height:64px; flex:none; color:var(--teal); }
.cert-mark svg{ width:100%; height:100%; }
.cert.pending .cert-mark{ color:var(--gold); }
.cert .status{ font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--teal); padding:6px 10px; border-radius:999px; background:rgba(15,110,86,.08); font-weight:500; flex:none; }
.cert.pending .status{ color:#9b6f1c; background:rgba(239,159,39,.12); }
.cert h3{ font-size:22px; margin:0; }
.cert p{ font-size:14.5px; line-height:1.55; margin:0; }
.cert-meta{ display:flex; gap:16px; flex-wrap:wrap; padding-top:14px; border-top:1px solid var(--border-soft); margin-top:auto; font-size:12px; color:var(--slate); font-family:var(--mono); letter-spacing:.04em; }

/* ---------- Quality: protocol list ---------- */
.protocol{ list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(2,1fr); gap:0 48px; }
@media (max-width:820px){ .protocol{ grid-template-columns:1fr; gap:0; } }
.protocol li{ display:flex; gap:24px; padding:28px 0; border-bottom:1px solid var(--border); }
.protocol li:last-child, .protocol li:nth-last-child(2){ border-bottom:none; }
@media (max-width:820px){ .protocol li:nth-last-child(2){ border-bottom:1px solid var(--border); } }
.protocol .num{ font-family:var(--serif); font-style:italic; font-weight:700; font-size:36px; color:var(--gold); line-height:1; flex:none; min-width:54px; letter-spacing:-.02em; }
.protocol h4{ font-family:var(--serif); font-size:20px; color:var(--teal-deep); margin:0 0 8px; font-weight:600; }
.protocol p{ font-size:14.5px; line-height:1.55; margin:0; }

/* ---------- Quality: COA mock ---------- */
.coa-mock{ background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:36px; box-shadow:var(--shadow-soft); max-width:900px; margin:0 auto; }
.coa-head{ display:flex; justify-content:space-between; gap:24px; padding-bottom:20px; border-bottom:2px solid var(--teal-deep); margin-bottom:24px; flex-wrap:wrap; }
.coa-brand{ display:flex; align-items:center; gap:10px; font-family:var(--serif); font-size:22px; color:var(--teal-deep); font-weight:600; }
.coa-brand img{ height:32px; }
.coa-sub{ font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-top:6px; font-weight:500; }
.coa-meta{ display:grid; gap:6px; font-family:var(--mono); font-size:12px; color:var(--slate); }
.coa-meta div span{ color:var(--slate-soft); margin-right:8px; letter-spacing:.06em; }
.coa-grid{ display:grid; gap:0; }
.coa-cell{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:16px; padding:12px 0; border-bottom:1px solid var(--border-soft); font-size:13.5px; align-items:center; }
.coa-cell:first-child{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--slate-soft); border-bottom:1px solid var(--border); padding-bottom:14px; }
.coa-cell .t{ color:var(--teal-deep); font-weight:500; }
.coa-foot{ display:flex; justify-content:space-between; align-items:flex-end; gap:24px; margin-top:28px; padding-top:24px; border-top:1px solid var(--border); flex-wrap:wrap; }
.coa-foot .sig .line{ font-family:var(--serif); font-size:18px; font-style:italic; color:var(--teal-deep); border-bottom:1px solid var(--charcoal); padding-bottom:4px; min-width:240px; }
.coa-foot .caption{ font-size:11.5px; color:var(--slate); margin-top:6px; max-width:36ch; }
.coa-foot .stamp{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); border:1.5px dashed var(--gold); padding:10px 16px; border-radius:6px; transform:rotate(-3deg); }

/* ---------- Shipping: incoterm grid ---------- */
.incoterm-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
@media (max-width:1000px){ .incoterm-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .incoterm-grid{ grid-template-columns:1fr; } }
.incoterm{ background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:28px; display:flex; flex-direction:column; gap:10px; transition:transform 200ms,box-shadow 200ms; }
.incoterm:hover{ transform:translateY(-2px); box-shadow:var(--shadow-soft); }
.incoterm .abbr{ font-family:var(--serif); font-style:italic; font-weight:700; font-size:48px; line-height:1; color:var(--gold); letter-spacing:-.02em; }
.incoterm h3{ font-size:20px; margin:0; }
.incoterm p{ font-size:14px; line-height:1.55; margin:0; flex:1; }
.incoterm .badge{ font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--teal); font-weight:500; margin-top:8px; }

/* ---------- Shipping: timeline (vertical) ---------- */
.timeline{ position:relative; padding:8px 0; max-width:760px; margin:0 auto; }
.timeline::before{ content:""; position:absolute; left:13px; top:18px; bottom:18px; width:2px; background:linear-gradient(var(--teal),var(--gold)); border-radius:2px; }
.timeline .step{ display:grid; grid-template-columns:auto 1fr; gap:28px; padding:18px 0; border-top:none; }
.timeline .step .dot{ width:28px; height:28px; border-radius:50%; background:#fff; border:2px solid var(--teal); position:relative; z-index:1; margin-top:4px; }
.timeline .step .dot::after{ content:""; position:absolute; inset:5px; border-radius:50%; background:var(--gold); }
.timeline .step h4{ font-family:var(--serif); font-size:21px; color:var(--teal-deep); margin:0 0 6px; font-weight:600; }
.timeline .step p{ font-size:14.5px; line-height:1.55; margin:0; }

/* ---------- Shipping: packaging grid ---------- */
.pack-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
@media (max-width:720px){ .pack-grid{ grid-template-columns:1fr; } }
.pack{ background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:0; display:flex; flex-direction:column; overflow:hidden; }
.pack .pack-body{ padding:20px 24px 24px; display:flex; flex-direction:column; gap:8px; }
.pack-vis{ aspect-ratio:1/1.1; background:linear-gradient(180deg,#fbf8ee,#f0e8d6); border-radius:10px; padding:16px; display:flex; align-items:center; justify-content:center; }
.pack h3{ font-size:20px; margin:0; }
.pack .pack-spec{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--teal-deep); }
.pack p{ font-size:14px; line-height:1.55; margin:0; color:var(--ink-2,#5b6157); }

/* ---------- Shipping: docs ---------- */
.docs-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media (max-width:900px){ .docs-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:540px){ .docs-grid{ grid-template-columns:1fr; } }
.doc{ background:#fff; border:1px solid var(--border); border-radius:12px; padding:24px; display:flex; flex-direction:column; gap:10px; }
.doc svg{ width:28px; height:28px; color:var(--teal); }
.doc h4{ font-family:var(--serif); font-size:20px; color:var(--teal-deep); margin:0; font-weight:600; }
.doc p{ font-size:13.5px; line-height:1.55; margin:0; }

/* ---------- Shipping: watermark band ---------- */
.watermark-band, .watermark-hero{ position:relative; isolation:isolate; }
.watermark-band::after{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 600'><g fill='none' stroke='%230F6E56' stroke-width='.8' opacity='.18'><circle cx='150' cy='180' r='90'/><circle cx='150' cy='180' r='130'/><circle cx='650' cy='420' r='80'/><circle cx='650' cy='420' r='120'/><path d='M0 320 Q200 200 420 280 T800 240' stroke-dasharray='3 6'/></g><g fill='%230F6E56' opacity='.18'><circle cx='150' cy='180' r='3'/><circle cx='420' cy='280' r='3'/><circle cx='650' cy='420' r='3'/></g></svg>");
  background-size:cover; background-position:center; opacity:.55;
}
.watermark-band > .container{ position:relative; z-index:1; }
.watermark-hero::after{
  content:""; position:absolute; right:-40px; top:40px; width:240px; height:240px; pointer-events:none; z-index:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><g fill='none' stroke='%23F5C36A' stroke-width='1' opacity='.5'><circle cx='100' cy='100' r='90'/><circle cx='100' cy='100' r='66'/><circle cx='100' cy='100' r='42'/></g></svg>");
  opacity:.6;
}

/* ---------- Contact: tabs + form panes ---------- */
.contact-tabs{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:36px; }
@media (max-width:760px){ .contact-tabs{ grid-template-columns:1fr; } }
.ctab{ background:#fff; border:1px solid var(--border); border-radius:12px; padding:20px 22px; text-align:left; display:flex; flex-direction:column; gap:6px; transition:all 180ms; }
.ctab:hover{ border-color:var(--teal); transform:translateY(-1px); }
.ctab.is-active{ border-color:var(--teal-deep); background:var(--teal-deep); color:#fff; box-shadow:var(--shadow-soft); }
.ctab.is-active .ctab-label{ color:var(--gold); }
.ctab.is-active .ctab-sub{ color:rgba(249,248,243,.75); }
.ctab-label{ font-family:var(--mono); font-size:11.5px; letter-spacing:.14em; color:var(--gold); font-weight:500; }
.ctab-title{ font-family:var(--serif); font-size:22px; font-weight:600; line-height:1.15; }
.ctab-sub{ font-size:13px; color:var(--slate); }

.contact-layout{ display:grid; grid-template-columns:1.5fr 1fr; gap:36px; align-items:start; }
@media (max-width:900px){ .contact-layout{ grid-template-columns:1fr; } }
.contact-form{ background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:clamp(28px,3.6vw,44px); box-shadow:var(--shadow-soft); }
.form-pane{ display:none; }
.form-pane.is-active{ display:block; }
.form-title{ font-family:var(--serif); font-size:30px; color:var(--teal-deep); margin:0 0 6px; font-weight:600; }
.form-sub{ font-size:14.5px; line-height:1.55; color:var(--slate); margin:0 0 22px; max-width:56ch; }
.contact-form .grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px; }
@media (max-width:540px){ .contact-form .grid-2{ grid-template-columns:1fr; } }
.contact-form label{ display:flex; flex-direction:column; gap:6px; font-size:12px; letter-spacing:.08em; text-transform:uppercase; font-weight:500; color:var(--slate); margin-bottom:14px; }
.contact-form label.full{ display:flex; }
.contact-form input, .contact-form select, .contact-form textarea{ font:inherit; font-size:15px; padding:12px 14px; border-radius:10px; border:1px solid var(--border); background:var(--bg); color:var(--charcoal); text-transform:none; letter-spacing:0; transition:all 160ms; }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus{ outline:none; border-color:var(--teal); background:#fff; box-shadow:0 0 0 3px rgba(15,110,86,.12); }
.contact-form textarea{ resize:vertical; min-height:100px; }
.contact-form fieldset{ border:none; padding:0; margin:0 0 14px; }
.contact-form fieldset legend{ font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--slate); padding:0; margin-bottom:10px; font-weight:500; }
.check-row{ display:flex; flex-wrap:wrap; gap:14px 24px; }
.check-row .check{ display:inline-flex; align-items:center; gap:8px; font-size:14px; text-transform:none; letter-spacing:0; color:var(--charcoal); margin-bottom:0; flex-direction:row; font-weight:400; }
.check-row .check input{ accent-color:var(--teal); }
.form-foot{ display:flex; justify-content:space-between; align-items:center; gap:18px; padding-top:18px; border-top:1px solid var(--border-soft); margin-top:8px; flex-wrap:wrap; }
.finep{ font-size:12px; color:var(--slate-soft); margin:0; max-width:50ch; }
.form-success{ text-align:center; padding:40px 20px; }
.check-circle{ width:72px; height:72px; border-radius:50%; background:linear-gradient(140deg,var(--teal),var(--teal-deep)); color:#fff; display:grid; place-items:center; margin:0 auto 18px; }
.check-circle svg{ width:32px; height:32px; }
.form-success h3{ font-size:28px; margin:0 0 10px; }
.form-success p{ font-size:15px; line-height:1.6; }

/* ---------- Contact: side cards ---------- */
.contact-side{ display:grid; gap:18px; }
.contact-side .card{ background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:24px 26px; }
.contact-side .card-quiet{ background:var(--cream); border-color:rgba(239,159,39,.3); }
.contact-side h4{ font-family:var(--serif); font-size:19px; color:var(--teal-deep); margin:0 0 14px; font-weight:600; }
.contact-side .cinfo{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; font-size:14px; }
.contact-side .cinfo li{ display:flex; justify-content:space-between; gap:14px; padding-bottom:8px; border-bottom:1px solid var(--border-soft); }
.contact-side .cinfo li:last-child{ border-bottom:none; padding-bottom:0; }
.contact-side .cinfo span{ color:var(--slate-soft); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; }
.contact-side .cinfo a{ color:var(--teal-deep); text-decoration:none; font-weight:500; }
.contact-side .cinfo a:hover{ color:var(--gold); }
.contact-side .addr{ font-size:14px; line-height:1.6; color:var(--charcoal); margin:0 0 14px; }
.contact-side .next{ list-style:none; counter-reset:n; padding:0; margin:0; display:flex; flex-direction:column; gap:14px; }
.contact-side .next li{ counter-increment:n; padding-left:34px; position:relative; font-size:14px; line-height:1.55; }
.contact-side .next li::before{ content:counter(n,decimal-leading-zero); position:absolute; left:0; top:0; font-family:var(--mono); font-size:12px; color:var(--gold); font-weight:600; letter-spacing:.06em; }

/* ---------- Insights ---------- */
.featured-post{ display:grid; grid-template-columns:1.1fr .9fr; gap:0; background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; margin-bottom:48px; box-shadow:var(--shadow-soft); }
@media (max-width:820px){ .featured-post{ grid-template-columns:1fr; } }
.fp-img{ aspect-ratio:3/2; overflow:hidden; background:var(--bg-2); }
.fp-img img{ width:100%; height:100%; object-fit:contain; }
.fp-body{ padding:clamp(28px,3.5vw,44px); display:flex; flex-direction:column; justify-content:center; gap:14px; }
.fp-body h2{ font-family:var(--serif); font-size:clamp(28px,3vw,38px); color:var(--teal-deep); margin:0; font-weight:600; line-height:1.12; text-wrap:balance; }
.fp-body p{ font-size:16px; line-height:1.6; margin:0; }
.post-tag{ display:inline-block; font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); font-weight:600; }
.post-meta{ display:flex; gap:10px; font-family:var(--mono); font-size:11.5px; letter-spacing:.06em; color:var(--slate-soft); margin-top:4px; }
.link-arrow{ display:inline-flex; align-items:center; gap:8px; color:var(--teal-deep); text-decoration:none; font-weight:500; font-size:14.5px; margin-top:6px; transition:gap 180ms,color 180ms; }
.link-arrow:hover{ color:var(--gold); gap:14px; }

.post-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media (max-width:960px){ .post-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .post-grid{ grid-template-columns:1fr; } }
.post{ background:#fff; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; padding:0 0 24px; transition:transform 200ms,box-shadow 200ms,border-color 200ms; display:flex; flex-direction:column; }
.post:hover{ transform:translateY(-2px); box-shadow:var(--shadow-soft); border-color:rgba(15,110,86,.25); }
.p-img{ aspect-ratio:3/2; overflow:hidden; margin-bottom:18px; background:var(--bg-2); }
.p-img img{ width:100%; height:100%; object-fit:contain; transition:transform 600ms; }
.post:hover .p-img img{ transform:scale(1.04); }
.post .post-tag{ padding:0 22px; }
.post h3{ font-size:21px; margin:8px 22px 8px; line-height:1.2; }
.post p{ font-size:14.5px; line-height:1.55; margin:0 22px 14px; flex:1; }
.post .post-meta{ padding:0 22px; }

/* Insights newsletter */
.newsletter{ display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:center; background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:clamp(32px,4vw,56px); box-shadow:var(--shadow-soft); }
@media (max-width:820px){ .newsletter{ grid-template-columns:1fr; gap:24px; } }
.newsletter h2{ font-size:clamp(28px,2.6vw,38px); margin:8px 0 10px; }
.newsletter p{ margin:0; }
.news-form{ display:grid; gap:14px; }
.news-form label{ display:flex; flex-direction:column; gap:6px; font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--slate); font-weight:500; }
.news-form input{ font:inherit; font-size:15px; padding:14px 16px; border-radius:10px; border:1px solid var(--border); background:var(--bg); text-transform:none; letter-spacing:0; }
.news-form input:focus{ outline:none; border-color:var(--teal); background:#fff; box-shadow:0 0 0 3px rgba(15,110,86,.12); }
.news-form .ns-msg{ font-size:14px; color:var(--teal); margin:0; padding:10px 14px; background:rgba(15,110,86,.08); border-radius:8px; }

/* About: refresh fact list look used inside grid */
.fact .num em{ font-style:italic; color:var(--gold); font-weight:700; }

/* ---------- Article (field note) layout ---------- */
.article-hero{ padding:clamp(120px,14vh,160px) 0 clamp(40px,6vh,72px); background:linear-gradient(180deg,#0A5040 0%,#0F6E56 100%); color:#F9F8F3; position:relative; overflow:hidden; }
.article-hero::after{ content:""; position:absolute; inset:auto -10% -50% -10%; height:60%; background:radial-gradient(60% 60% at 50% 0%,rgba(239,159,39,.18),transparent 70%); pointer-events:none; }
.article-hero .crumbs{ font-family:var(--mono); font-size:11.5px; letter-spacing:.08em; color:rgba(249,248,243,.7); margin-bottom:18px; }
.article-hero .crumbs a{ color:inherit; text-decoration:none; }
.article-hero .crumbs a:hover{ color:var(--gold); }
.article-hero .crumbs span{ margin:0 10px; opacity:.5; }
.article-hero .post-tag{ color:var(--gold-soft); }
.article-hero h1{ color:#F9F8F3; font-size:clamp(32px,4.6vw,56px); line-height:1.08; margin:14px 0 22px; max-width:22ch; }
.article-hero h1 em{ color:var(--gold); }
.article-hero .post-meta{ color:rgba(249,248,243,.7); font-family:var(--mono); font-size:12px; letter-spacing:.08em; display:flex; flex-wrap:wrap; gap:10px; }
.article-hero .post-meta span{ display:inline-flex; gap:10px; }
.article-cover{ max-width:var(--maxw); margin:-40px auto 0; padding:0 var(--gutter); position:relative; z-index:2; }
.article-cover img{ width:100%; aspect-ratio:3/2; object-fit:contain; background:var(--bg-2); border-radius:var(--radius-lg); box-shadow:var(--shadow-lift); }

.article-body{ padding:clamp(40px,7vh,80px) 0 clamp(60px,8vh,100px); }
.article-body .container{ display:grid; grid-template-columns:minmax(0,1fr); justify-items:center; }
.article-prose{ max-width:680px; width:100%; }
.article-prose .lede{ font-family:var(--serif); font-style:italic; font-size:clamp(20px,2vw,24px); line-height:1.45; color:var(--teal-deep); margin:0 0 32px; padding-bottom:28px; border-bottom:1px solid var(--border); text-wrap:pretty; }
.article-prose h2{ font-family:var(--serif); font-weight:600; font-size:clamp(24px,2.4vw,30px); color:var(--teal-deep); margin:48px 0 14px; line-height:1.2; letter-spacing:-.01em; }
.article-prose h2:first-child{ margin-top:0; }
.article-prose h3{ font-family:var(--sans); font-weight:600; font-size:18px; color:var(--charcoal); margin:32px 0 10px; }
.article-prose p{ font-size:17px; line-height:1.7; margin:0 0 18px; color:var(--slate); text-wrap:pretty; }
.article-prose p strong{ color:var(--charcoal); font-weight:600; }
.article-prose a{ color:var(--teal-deep); text-decoration:underline; text-decoration-color:rgba(15,110,86,.3); text-underline-offset:3px; }
.article-prose a:hover{ color:var(--gold); }
.article-prose ul, .article-prose ol{ font-size:17px; line-height:1.7; color:var(--slate); padding-left:22px; margin:0 0 22px; }
.article-prose li{ margin-bottom:8px; }
.article-prose li::marker{ color:var(--gold); }
.article-prose blockquote{ margin:32px 0; padding:4px 0 4px 24px; border-left:3px solid var(--gold); font-family:var(--serif); font-style:italic; font-size:22px; line-height:1.4; color:var(--teal-deep); }
.article-prose blockquote cite{ display:block; font-family:var(--mono); font-style:normal; font-size:12px; letter-spacing:.08em; color:var(--slate-soft); margin-top:10px; text-transform:uppercase; }
.article-prose .callout{ background:var(--bg-2); border:1px solid var(--border-soft); border-left:3px solid var(--teal); border-radius:8px; padding:20px 22px; margin:28px 0; font-size:15.5px; line-height:1.6; color:var(--slate); }
.article-prose .callout strong{ display:block; font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--teal); margin-bottom:6px; }
.article-prose .data-table{ width:100%; border-collapse:collapse; margin:22px 0 28px; font-size:14.5px; }
.article-prose .data-table th, .article-prose .data-table td{ padding:11px 14px; text-align:left; border-bottom:1px solid var(--border); }
.article-prose .data-table th{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--slate-soft); font-weight:600; background:var(--bg-2); }
.article-prose .data-table td{ color:var(--charcoal); }
.article-prose .data-table tbody tr:hover{ background:rgba(15,110,86,.03); }
.article-prose figure{ margin:32px 0; }
.article-prose figure img{ width:100%; border-radius:var(--radius); }
.article-prose figcaption{ font-family:var(--mono); font-size:11.5px; letter-spacing:.06em; color:var(--slate-soft); margin-top:10px; text-align:center; }
.article-prose hr{ border:none; height:1px; background:var(--border); margin:40px 0; }
.article-prose .end-mark{ font-family:var(--serif); font-style:italic; color:var(--gold); font-size:22px; text-align:center; margin:40px 0 0; letter-spacing:.4em; }

.article-byline{ display:flex; align-items:center; gap:14px; margin:40px 0 0; padding:28px 0 0; border-top:1px solid var(--border); }
.article-byline .av{ width:48px; height:48px; border-radius:50%; background:linear-gradient(135deg,var(--teal),var(--teal-deep)); color:#F9F8F3; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-weight:600; font-size:18px; }
.article-byline .who{ display:flex; flex-direction:column; }
.article-byline .who b{ font-size:14.5px; color:var(--charcoal); font-weight:600; }
.article-byline .who span{ font-family:var(--mono); font-size:11.5px; letter-spacing:.06em; color:var(--slate-soft); }

.more-notes{ background:var(--bg-2); padding:clamp(56px,8vh,88px) 0; border-top:1px solid var(--border-soft); }
.more-notes h2{ font-family:var(--serif); font-weight:600; font-size:clamp(26px,2.6vw,34px); color:var(--teal-deep); margin:0 0 28px; }
.more-notes .post-grid{ grid-template-columns:repeat(3,1fr); }
@media (max-width:960px){ .more-notes .post-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .more-notes .post-grid{ grid-template-columns:1fr; } }
.more-notes .post{ border-color:var(--border-soft); }

.post-link{ display:block; color:inherit; text-decoration:none; }
.post-link:hover h3{ color:var(--teal-deep); }
