/*
Theme Name: Ridge Starter Pro 402
Author: Kai Design
Description: A minimal theme built with best practices.
Version: 3.2.7
Text Domain: ridge-starter-pro-402
Tested up to: 6.5
Tags: photography, portfolio, custom-menu, news
License: GNU General Public License v3 or later
License URI: https://www.gnu.org/licenses/gpl-3.0.html
*/

:root{
  --bg:#FAFAF8;
  --ink:#0A0A0A;
  --ink-2:#1F1F1F;
  --muted:#6E6E6E;
  --line:#1F1F1F;
  --line-soft:#E2E1DC;
  --accent:#D33F2A;
  --paper:#FFFFFF;
  --max:1280px;
  --gap:24px;
  --col:8.333%;
  --sans:'Space Grotesk','Helvetica Neue',Helvetica,Arial,sans-serif;
  --mono:'JetBrains Mono','IBM Plex Mono','Space Mono',ui-monospace,Menlo,monospace;
}
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{overflow-x:hidden}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;font-feature-settings:"ss01","cv11";
}
a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line)}
a:hover{color:var(--accent);border-color:var(--accent)}
img{max-width:100%;display:block;height:auto;filter:grayscale(8%)}
button{font-family:inherit;cursor:pointer}
.mono{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

.container{max-width:var(--max);margin:0 auto;padding:0 32px}

/* HEADER */
.site-header{
  background:var(--ink);color:var(--bg);
  border-bottom:1px solid var(--ink);
}
.header-row{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;max-width:var(--max);margin:0 auto;gap:24px}
.logo{display:flex;align-items:baseline;gap:10px;color:var(--bg);border:none;font-weight:600;font-size:18px;letter-spacing:-.02em}
.logo .dot{width:10px;height:10px;background:var(--accent);display:inline-block}
.logo .mono{color:var(--bg);opacity:.6}
.site-nav{display:flex;align-items:center;gap:28px}
.site-nav a{color:var(--bg);border:none;font-size:13px;letter-spacing:.04em;text-transform:uppercase}
.site-nav a:hover{color:var(--accent)}
.burger{display:none;background:none;border:1px solid var(--bg);color:var(--bg);padding:6px 10px;font-family:var(--mono);font-size:11px}

@media (max-width:860px){
  .site-nav{display:none;position:absolute;top:60px;left:0;right:0;background:var(--ink);flex-direction:column;align-items:flex-start;padding:18px 32px;gap:14px;z-index:30}
  .site-nav.open{display:flex}
  .burger{display:inline-block}
}

/* HERO */
.hero{
  border-bottom:1px solid var(--line);
  padding:80px 0 64px;
}
.hero-grid{
  display:flex;flex-wrap:wrap;align-items:stretch;gap:0;
}
.hero-left,.hero-right{flex:1 1 480px;padding:24px}
.hero-left{border-right:1px solid var(--line)}
.hero h1{
  font-size:clamp(38px,5.6vw,76px);line-height:1.02;letter-spacing:-.03em;
  font-weight:600;margin:24px 0;
}
.hero .tagline{font-size:18px;color:var(--ink-2);max-width:42ch;margin-bottom:36px}
.hero .meta-row{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:24px}
.hero .meta-row span{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}
.hero-right{background:var(--paper);display:flex;align-items:center;justify-content:center;min-height:420px;position:relative}
.hero-right::before{content:"";position:absolute;inset:24px;border:1px solid var(--line)}
.hero-right img{width:100%;height:100%;max-height:520px;object-fit:cover}

/* BUTTONS */
.btn{display:inline-block;padding:14px 22px;font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;border:1px solid var(--ink);background:transparent;color:var(--ink);transition:.18s ease}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:#A82E1D;border-color:#A82E1D;color:#fff}
.btn-ghost:hover{background:var(--ink);color:var(--bg)}

/* KEY FACTS strip */
.facts{border-bottom:1px solid var(--line);padding:48px 0}
.facts-grid{display:flex;flex-wrap:wrap;gap:0}
.fact{flex:1 1 220px;padding:24px;border-right:1px solid var(--line-soft)}
.fact:last-child{border-right:none}
.fact .num{font-size:clamp(40px,4.4vw,64px);font-weight:600;letter-spacing:-.03em;line-height:1}
.fact .label{margin-top:10px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}

/* ARTICLE */
.article{padding:72px 0}
.article-wrap{display:flex;flex-wrap:wrap;gap:48px;align-items:flex-start}
.article-aside{flex:0 0 160px;position:sticky;top:24px}
.article-aside ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.article-aside a{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;border:none;color:var(--muted)}
.article-aside a:hover{color:var(--accent)}
.article-main{flex:1 1 540px;max-width:780px}
.article-main h1{font-size:clamp(34px,4.2vw,56px);line-height:1.05;letter-spacing:-.02em;font-weight:600;margin-bottom:24px}
.article-main h2{font-size:28px;letter-spacing:-.01em;margin:48px 0 16px;font-weight:600;border-top:1px solid var(--line);padding-top:24px}
.article-main h3{font-size:20px;margin:28px 0 12px;font-weight:600}
.article-main p{margin:16px 0;color:var(--ink-2);font-size:17px;line-height:1.65}
.article-main ul, .article-main ol{margin:16px 0 16px 22px}
.article-main li{margin:8px 0;line-height:1.6}
.article-main blockquote{
  border:none;border-left:3px solid var(--accent);
  padding:8px 0 8px 24px;margin:36px 0;
  font-size:22px;line-height:1.45;font-weight:500;letter-spacing:-.01em;
  font-style:normal;color:var(--ink);
}
.article-main blockquote cite{display:block;margin-top:12px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);font-style:normal}
.breadcrumbs{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:24px}
.breadcrumbs a{border:none;color:var(--muted)}
.breadcrumbs a:hover{color:var(--accent)}
.meta-line{display:flex;flex-wrap:wrap;gap:18px;margin:8px 0 32px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* FAQ */
.faq{margin:48px 0;border-top:1px solid var(--line);padding-top:24px}
.faq details{border-bottom:1px solid var(--line-soft);padding:18px 0}
.faq summary{cursor:pointer;font-weight:600;font-size:18px;display:flex;justify-content:space-between;align-items:center;list-style:none}
.faq summary::after{content:"+";font-family:var(--mono);color:var(--accent);font-size:20px}
.faq details[open] summary::after{content:"−"}
.faq details p{margin-top:12px}

/* CALLOUT */
.callout{
  border:1px solid var(--line);padding:28px;margin:32px 0;
  display:flex;gap:24px;flex-wrap:wrap;
}
.callout .mark{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.18em;text-transform:uppercase;flex:0 0 80px}
.callout .body{flex:1 1 300px;color:var(--ink-2)}

/* DISCLAIMER */
.disclaimer{
  border:1px dashed var(--muted);
  padding:20px 24px;margin:48px 0 0;
  font-size:13px;color:var(--muted);line-height:1.5;
}

/* READ ALSO */
.read-also{border-top:1px solid var(--line);padding:64px 0;margin-top:64px}
.read-also h2{font-size:24px;margin-bottom:32px;font-weight:600}
.cards{display:flex;flex-wrap:wrap;gap:24px}
.card{
  flex:1 1 280px;border:1px solid var(--line-soft);
  padding:24px;background:var(--paper);transition:.18s ease;
}
.card:hover{border-color:var(--ink);transform:translateY(-2px)}
.card .mono{display:block;margin-bottom:12px}
.card h3{font-size:18px;line-height:1.25;font-weight:600;margin-bottom:12px}
.card a{border:none}
.card a:hover{color:var(--accent)}
.card .read{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);border:none;display:inline-block;margin-top:12px}

/* TAGS */
.tags{display:flex;flex-wrap:wrap;gap:8px;margin:32px 0;padding:24px 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.tag{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);border:1px solid var(--line-soft);padding:6px 10px}

/* SHARE rail */
.share-rail{display:flex;flex-direction:column;gap:10px;margin-top:48px}
.share-rail span{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.share-rail a{border:1px solid var(--line);padding:8px 10px;text-align:center;font-family:var(--mono);font-size:11px}

@media (max-width:860px){
  .article-wrap{gap:24px}
  .article-aside{position:static;flex:1 1 100%}
  .share-rail{flex-direction:row;flex-wrap:wrap}
}

/* SUBSCRIBE */
.subscribe{border-top:1px solid var(--line);padding:72px 0;background:var(--paper)}
.sub-grid{display:flex;flex-wrap:wrap;gap:48px;max-width:var(--max);margin:0 auto;padding:0 32px;align-items:flex-start}
.sub-text{flex:1 1 360px}
.sub-text h2{font-size:36px;line-height:1.05;margin:12px 0 16px;letter-spacing:-.02em;font-weight:600}
.sub-text p{color:var(--ink-2);max-width:46ch}
.sub-form{flex:1 1 360px;display:flex;flex-direction:column;gap:14px}
.sub-form label{display:flex;flex-direction:column;gap:6px}
.sub-form input{padding:14px 16px;border:1px solid var(--line);background:transparent;font-family:var(--sans);font-size:15px;color:var(--ink)}
.sub-form input:focus{outline:none;border-color:var(--accent)}

/* ABOUT mini */
.about-mini{border-top:1px solid var(--line);padding:72px 0}
.about-mini .ag{display:flex;flex-wrap:wrap;gap:48px}
.about-mini .col{flex:1 1 320px}
.about-mini h2{font-size:32px;margin:12px 0 16px;font-weight:600;letter-spacing:-.02em}
.about-mini p{color:var(--ink-2)}

/* AUTHOR card */
.author{border:1px solid var(--line-soft);padding:24px;margin:32px 0;background:var(--paper);display:flex;gap:20px;flex-wrap:wrap;align-items:center}
.author .avatar{width:56px;height:56px;border-radius:50%;background:var(--ink);color:var(--bg);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:14px;font-weight:600}
.author .a-body{flex:1 1 220px}
.author .a-body .role{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}
.author .a-body strong{font-size:16px}

/* FOOTER */
.site-footer{background:#0A0A0A;color:#A8A8A4;padding:72px 0 32px;border-top:1px solid #1F1F1F}
.footer-grid{display:flex;flex-wrap:wrap;gap:48px;max-width:var(--max);margin:0 auto;padding:0 32px}
.footer-brand{flex:2 1 320px}
.footer-brand .logo{color:#fff}
.footer-brand .logo .mono{color:#A8A8A4}
.footer-brand p{margin:18px 0;max-width:42ch;color:#A8A8A4;font-size:14px}
.footer-cols{flex:3 1 360px;display:flex;flex-wrap:wrap;gap:32px}
.footer-cols .col{flex:1 1 140px}
.footer-cols h4{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:#fff;margin-bottom:14px}
.footer-cols a{color:#A8A8A4;border:none;display:block;padding:5px 0;font-size:14px}
.footer-cols a:hover{color:#fff}
.footer-bottom{max-width:var(--max);margin:48px auto 0;padding:24px 32px 0;border-top:1px solid #1F1F1F;display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#6E6E6E}
.contact-info{font-size:14px;color:#A8A8A4;line-height:1.7;margin-top:14px}
.contact-info span{display:block}

/* COOKIE */
.cookie-banner{position:fixed;left:24px;right:24px;bottom:24px;background:#fff;border:1px solid var(--ink);padding:22px 24px;display:none;z-index:50;box-shadow:0 18px 60px rgba(0,0,0,.18)}
.cookie-banner.show{display:block}
.cb-grid{display:flex;flex-wrap:wrap;gap:18px;align-items:center}
.cb-text{flex:1 1 360px;font-size:14px;color:var(--ink-2)}
.cb-actions{display:flex;flex-wrap:wrap;gap:10px}
.cb-actions button{padding:10px 14px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--ink);background:transparent}
.cb-actions .accept{background:var(--accent);color:#fff;border-color:var(--accent)}
.cookie-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(10,10,10,.55);z-index:60;padding:24px}
.cookie-modal.show{display:flex}
.cm-card{background:#fff;max-width:560px;width:100%;padding:36px;border:1px solid var(--ink)}
.cm-card h3{margin-bottom:18px;font-size:22px}
.cm-row{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;padding:16px 0;border-top:1px solid var(--line-soft)}
.cm-row:first-of-type{border-top:none}
.cm-row .info{flex:1}
.cm-row .info strong{display:block;margin-bottom:4px}
.cm-row .info small{color:var(--muted);font-size:13px}
.switch{position:relative;width:46px;height:24px;flex:0 0 46px}
.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;inset:0;background:#E2E1DC;cursor:pointer;border:1px solid var(--line)}
.slider::before{content:"";position:absolute;left:2px;top:2px;width:18px;height:18px;background:#fff;border:1px solid var(--ink);transition:.18s}
.switch input:checked + .slider{background:var(--accent);border-color:var(--accent)}
.switch input:checked + .slider::before{transform:translateX(20px);border-color:var(--accent)}
.switch input:disabled + .slider{opacity:.55;cursor:not-allowed}
.cm-actions{margin-top:24px;display:flex;justify-content:flex-end;gap:10px}

/* CONTACT page */
.contact-grid{display:flex;flex-wrap:wrap;gap:48px;padding:64px 0}
.contact-info-box{flex:1 1 320px}
.contact-info-box dl{display:flex;flex-direction:column;gap:18px;margin-top:24px}
.contact-info-box dt{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em}
.contact-info-box dd{font-size:18px;margin-top:4px}
.contact-form{flex:1 1 320px;display:flex;flex-direction:column;gap:14px;padding:32px;border:1px solid var(--line)}
.contact-form input,.contact-form textarea{padding:14px 16px;border:1px solid var(--line);background:transparent;font-family:var(--sans);font-size:15px;color:var(--ink)}

/* LEGAL */
.legal{padding:72px 0;max-width:820px;margin:0 auto;padding-left:32px;padding-right:32px}
.legal h1{font-size:clamp(32px,4vw,52px);font-weight:600;letter-spacing:-.02em;margin-bottom:8px}
.legal .updated{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:32px}
.legal h2{font-size:22px;margin:40px 0 12px;font-weight:600;border-top:1px solid var(--line);padding-top:24px}
.legal h3{font-size:18px;margin:24px 0 8px;font-weight:600}
.legal p{margin:12px 0;color:var(--ink-2)}
.legal ul{margin:12px 0 12px 22px}
.legal li{margin:6px 0}

/* SUCCESS */
.success{padding:120px 0;text-align:center}
.success h1{font-size:clamp(48px,7vw,96px);font-weight:600;letter-spacing:-.03em;line-height:1.02}
.success .mark{font-family:var(--mono);color:var(--accent);letter-spacing:.16em;text-transform:uppercase;font-size:12px;display:block;margin-bottom:24px}
.success p{margin:24px auto;max-width:520px;font-size:18px;color:var(--ink-2)}

/* 404 */
.page-404{padding:120px 0;text-align:center}
.page-404 .big{font-family:var(--mono);font-size:clamp(96px,18vw,220px);color:var(--accent);line-height:1;letter-spacing:-.05em}
.page-404 h1{font-size:32px;margin:16px 0}

/* CTA banner */
.cta-banner{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:48px 0;background:var(--bg)}
.cta-inner{display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:space-between;max-width:var(--max);margin:0 auto;padding:0 32px}
.cta-inner h3{font-size:22px;font-weight:600;letter-spacing:-.01em;max-width:46ch}
