/* ================================================================
   Copywriter Masterclass — Newspaper Editorial Layout
   LEFT SIDEBAR NAVIGATION (persistent, not top, not bottom!)
   Multi-column hero like a broadsheet · Drop cap
   Classified-style service grid · Roman numeral process
   Fonts: IBM Plex Mono (labels/accents) + IBM Plex Sans (body)
   Palette: Black + electric violet on newsprint white
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:ital,wght@0,400;0,500;0,600;0,700;1,400&family=IBM+Plex+Sans:wght@300;400;500;600;700&display=swap');

:root{
--primary:#0a0a0a;--primary-lt:#2d2d2d;
--accent:#7c3aed;--accent-lt:#a78bfa;--accent-dk:#5b21b6;
--bg:#f8f6f1;--surface:#fff;--surface2:#f0ede5;--surface3:#e5e1d6;
--text:#0a0a0a;--muted:#6b6860;--border:#d4d0c6;--border-dk:#b8b3a5;
--white:#fff;--black:#0a0a0a;
--font-h:'IBM Plex Mono',monospace;--font-b:'IBM Plex Sans',sans-serif;
--sidebar-w:220px;--max-w:900px;--tr:.25s ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}
body{font-family:var(--font-b);color:var(--text);background:var(--bg);line-height:1.8;-webkit-font-smoothing:antialiased;font-size:15px}
img{max-width:100%;height:auto;display:block}a{color:var(--accent-dk);text-decoration:none;transition:color var(--tr)}a:hover{color:var(--accent)}
ul,ol{list-style:none}

/* ── LEFT SIDEBAR NAVIGATION (persistent on desktop) ── */
.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);background:var(--black);color:var(--white);display:flex;flex-direction:column;z-index:100;overflow-y:auto}
.sb-brand{padding:28px 20px;border-bottom:1px solid rgba(255,255,255,.06)}
.sb-brand a{font-family:var(--font-h);font-size:.68rem;font-weight:700;color:var(--white);text-transform:uppercase;letter-spacing:2px;text-decoration:none;display:block;line-height:1.4}
.sb-brand .sb-mark{font-size:1.8rem;color:var(--accent);display:block;margin-bottom:6px;font-weight:400}
.sb-nav{flex:1;padding:24px 20px;display:flex;flex-direction:column;gap:4px}
.sb-nav a{font-family:var(--font-h);font-size:.62rem;font-weight:500;text-transform:uppercase;letter-spacing:2.5px;color:rgba(255,255,255,.35);padding:8px 0;display:block;border-bottom:1px solid rgba(255,255,255,.04);transition:color var(--tr)}
.sb-nav a:hover,.sb-nav a.active{color:var(--white)}
.sb-nav a.active{color:var(--accent-lt)}
.sb-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.06);font-size:.56rem;color:rgba(255,255,255,.15)}
.sb-cta{display:block;margin:12px 20px 0;padding:12px;background:var(--accent);color:var(--white);text-align:center;font-family:var(--font-h);font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;text-decoration:none;transition:background var(--tr)}
.sb-cta:hover{background:var(--accent-dk);color:var(--white)}
/* Mobile sidebar toggle */
.sb-toggle{display:none;position:fixed;top:16px;left:16px;z-index:101;background:var(--black);color:var(--white);border:none;padding:10px 14px;cursor:pointer;font-family:var(--font-h);font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:2px}
@media(max-width:900px){
.sidebar{transform:translateX(-100%);transition:transform .3s ease}.sidebar.open{transform:translateX(0)}
.sb-toggle{display:block}
.main-content{margin-left:0!important}
}

/* ── MAIN CONTENT — offset by sidebar width ── */
.main-content{margin-left:var(--sidebar-w)}
.mc{max-width:var(--max-w);margin:0 auto;padding:0 40px}
h1,h2,h3,h4{color:var(--text)}
h1{font-family:var(--font-b);font-size:clamp(2rem,4.5vw,3rem);font-weight:300;letter-spacing:-.02em;line-height:1.15}
h2{font-family:var(--font-b);font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:300;line-height:1.15}
h3{font-family:var(--font-b);font-size:1.1rem;font-weight:600}
.mono{font-family:var(--font-h)}
.label{font-family:var(--font-h);font-size:.54rem;font-weight:600;text-transform:uppercase;letter-spacing:4px;color:var(--accent);margin-bottom:14px;display:block}
.btn{display:inline-flex;align-items:center;gap:6px;padding:14px 32px;font-family:var(--font-h);font-weight:600;font-size:.64rem;text-transform:uppercase;letter-spacing:2.5px;border:1.5px solid var(--black);color:var(--black);background:transparent;cursor:pointer;transition:all var(--tr);text-decoration:none}
.btn:hover{background:var(--black);color:var(--white)}
.btn-violet{background:var(--accent);border-color:var(--accent);color:var(--white)}.btn-violet:hover{background:var(--accent-dk);border-color:var(--accent-dk)}

/* ── HERO — NEWSPAPER BROADSHEET (multi-column + drop cap) ── */
.hero-paper{padding:80px 0 48px;border-bottom:2px solid var(--black)}
.hero-edition{font-family:var(--font-h);font-size:.54rem;text-transform:uppercase;letter-spacing:4px;color:var(--muted);margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}
.hero-edition::after{content:'';flex:1;height:1px;background:var(--border);margin-left:16px}
.hero-masthead{font-family:var(--font-h);font-size:clamp(.7rem,1.2vw,1rem);font-weight:700;text-transform:uppercase;letter-spacing:6px;text-align:center;padding:16px 0;border-top:4px solid var(--black);border-bottom:1px solid var(--black);margin-bottom:24px}
.hero-hl{margin-bottom:24px}
.hero-cols{column-count:2;column-gap:32px;column-rule:1px solid var(--border)}
.hero-cols .dropcap::first-letter{font-family:var(--font-b);float:left;font-size:4.2rem;font-weight:700;line-height:.75;margin:4px 10px 0 0;color:var(--accent)}
.hero-cols p{color:var(--muted);font-size:.92rem;margin-bottom:14px}
.hero-cta-bar{display:flex;justify-content:space-between;align-items:center;margin-top:28px;padding-top:20px;border-top:1px solid var(--border)}
.hero-nums{display:flex;gap:28px}.hn-v{font-family:var(--font-h);font-size:1.1rem;font-weight:700;color:var(--accent)}.hn-l{font-size:.52rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
@media(max-width:700px){.hero-cols{column-count:1}}

/* ── Pull quote — editorial divider ── */
.pullquote{padding:40px 0;border-bottom:1px solid var(--border);text-align:center}
.pullquote blockquote{font-family:var(--font-b);font-size:clamp(1.1rem,2vw,1.5rem);font-weight:300;font-style:italic;line-height:1.6;max-width:580px;margin:0 auto;color:var(--text);position:relative;padding:0 20px}
.pullquote blockquote::before,.pullquote blockquote::after{content:'—';display:block;color:var(--accent);font-style:normal;margin:12px 0}

/* ── Services — CLASSIFIED ADS GRID (newspaper columns!) ── */
.classifieds{padding:60px 0;border-bottom:1px solid var(--border)}
.cf-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--border)}
.cf-item{padding:24px 20px;border:1px solid var(--border);transition:background var(--tr);text-decoration:none;color:var(--text);display:block}
.cf-item:hover{background:var(--surface2)}
.cf-num{font-family:var(--font-h);font-size:.52rem;color:var(--accent);letter-spacing:2px;margin-bottom:6px;display:block}
.cf-item h3{font-size:1rem;margin-bottom:6px;font-weight:600}
.cf-item p{color:var(--muted);font-size:.8rem;margin-bottom:10px}
.cf-price{font-family:var(--font-h);font-size:.72rem;font-weight:700;color:var(--accent)}
@media(max-width:600px){.cf-grid{grid-template-columns:1fr}}

/* ── Process — ROMAN NUMERALS with separator lines ── */
.proc-section{padding:60px 0;border-bottom:1px solid var(--border)}
.proc-items{display:flex;flex-direction:column;gap:0}
.pi{display:grid;grid-template-columns:80px 1fr;gap:20px;padding:24px 0;border-bottom:1px solid var(--border)}
.pi:last-child{border-bottom:none}
.pi-n{font-family:var(--font-h);font-size:2rem;font-weight:400;color:var(--accent);line-height:1}
.pi h3{margin-bottom:4px;font-size:1rem}.pi p{color:var(--muted);font-size:.86rem;margin:0}

/* ── Testimonials — NEWSPAPER QUOTES with rule above ── */
.quotes-section{padding:60px 0;border-bottom:1px solid var(--border)}
.q-stack{display:flex;flex-direction:column;gap:0}
.q-item{padding:28px 0;border-bottom:1px solid var(--border)}
.q-item:last-child{border-bottom:none}
.q-item p{font-style:italic;color:var(--muted);font-size:.9rem;margin-bottom:10px;max-width:660px}
.q-attr{font-family:var(--font-h);font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--accent)}

/* ── Pricing — COMPARISON TABLE (not cards!) ── */
.section{padding:60px 0}.section-hdr{margin-bottom:40px}
.price-table{width:100%;border-collapse:collapse;font-size:.82rem}
.price-table th{font-family:var(--font-h);font-size:.56rem;text-transform:uppercase;letter-spacing:2px;padding:14px 12px;border-bottom:2px solid var(--black);text-align:left;color:var(--muted)}
.price-table th.pop{color:var(--accent)}
.price-table td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:top}
.price-table tr:hover td{background:var(--surface2)}
.price-table .plan-name{font-family:var(--font-h);font-weight:700;font-size:.9rem}
.price-table .plan-amt{font-family:var(--font-h);font-size:1.3rem;color:var(--accent);font-weight:400}
.price-table .feat{color:var(--muted)}
.price-table .feat-yes{color:var(--accent);font-weight:700}

/* ── Builder / Checkout / About / FAQ / Contact / CTA ── */
.builder-box{max-width:600px;background:var(--surface);border:1px solid var(--border);padding:36px 28px}
.addon-stack{display:flex;flex-direction:column;gap:6px;margin-bottom:24px}
.addon-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border:1px solid var(--border);cursor:pointer;transition:border-color var(--tr)}.addon-row:hover{border-color:var(--accent)}
.addon-row label{display:flex;align-items:center;gap:10px;cursor:pointer;flex:1;font-size:.86rem}.addon-row input[type="checkbox"]{accent-color:var(--accent)}
.addon-cost{font-family:var(--font-h);font-weight:600;color:var(--accent);font-size:.8rem}
.sup-block{margin-bottom:24px}.range-bar{display:flex;align-items:center;gap:10px}.range-bar input[type="range"]{flex:1;accent-color:var(--accent)}
.range-val{font-family:var(--font-h);font-weight:700;color:var(--accent)}
.build-total{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-top:2px solid var(--accent);margin-top:8px}
.build-total .bt-val{font-family:var(--font-h);font-size:1.8rem;color:var(--accent)}
.co-wrap{max-width:480px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-group{display:flex;flex-direction:column;gap:4px}.form-group.full{grid-column:1/-1}
.form-group label{font-family:var(--font-h);font-size:.56rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:2px}
.form-group input,.form-group select,.form-group textarea{padding:12px 14px;background:var(--bg);border:1px solid var(--border);color:var(--text);font-family:var(--font-b);font-size:.86rem;transition:border-color var(--tr)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}
@media(max-width:500px){.form-grid{grid-template-columns:1fr}}
.cb-agree{display:flex;align-items:flex-start;gap:10px;margin-top:16px;font-size:.74rem;color:var(--muted)}.cb-agree input{accent-color:var(--accent);margin-top:3px}.cb-agree a{color:var(--accent-dk);text-decoration:underline}
.order-box{background:var(--surface2);border:1px solid var(--border);padding:22px;margin-bottom:22px}.order-box h3{margin-bottom:8px;font-size:.95rem}
.ol{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border);font-size:.84rem}
.ol.tot{border-bottom:none;border-top:2px solid var(--accent);margin-top:6px;padding-top:8px;font-weight:700}.ol.tot span:last-child{color:var(--accent)}
.about-body{max-width:600px}.about-body p{color:var(--muted)}.about-img{aspect-ratio:16/9;overflow:hidden;background:var(--surface2);margin:36px 0;border:1px solid var(--border)}.about-img img{width:100%;height:100%;object-fit:cover}
.vals-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;border-top:1px solid var(--border);padding-top:36px}
.val-item h3{color:var(--accent);font-size:.95rem;margin-bottom:4px}.val-item p{color:var(--muted);font-size:.82rem;margin:0}
@media(max-width:600px){.vals-row{grid-template-columns:1fr}}
.faq-list{max-width:600px}.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;padding:18px 0;background:none;border:none;color:var(--text);font-family:var(--font-b);font-weight:600;font-size:.9rem;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center}.faq-q:hover{color:var(--accent)}
.faq-ic{transition:transform var(--tr);color:var(--muted);font-family:var(--font-h);font-size:.8rem}.faq-item.open .faq-ic{transform:rotate(45deg);color:var(--accent)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}.faq-a-inner{padding:0 0 18px;color:var(--muted);font-size:.86rem}
.ct-centered{max-width:520px}.ct-info{display:flex;gap:32px;margin-bottom:32px;flex-wrap:wrap}
.ct-info div{font-size:.8rem;color:var(--muted)}.ct-info a{color:var(--accent-dk)}
.ct-info span{display:block;font-family:var(--font-h);font-size:.52rem;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--border-dk);margin-bottom:2px}
.ct-form{border:1px solid var(--border);padding:32px 24px;background:var(--surface)}
.cta-editorial{padding:80px 0;text-align:center;border-top:2px solid var(--black);border-bottom:2px solid var(--black)}
.cta-editorial h2{max-width:600px;margin:0 auto 12px}.cta-editorial p{color:var(--muted);margin-bottom:24px}
/* Service detail */
.svc-head{padding:80px 0 40px;border-bottom:1px solid var(--border)}
.svc-head h1{margin-bottom:8px}
.svc-head .svc-fprice{font-family:var(--font-h);font-size:1.3rem;color:var(--accent);margin:8px 0 16px}
.svc-body{max-width:600px;padding:48px 0}.svc-body p{color:var(--muted);font-size:.92rem}
.svc-body .svc-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}
.pg-head{padding:80px 0 40px;border-bottom:1px solid var(--border)}.pg-head h1{margin-bottom:8px}.pg-head p{color:var(--muted);max-width:460px}
.legal{max-width:580px}.legal h2{font-family:var(--font-h);font-size:.9rem;font-weight:600;margin:24px 0 6px}.legal h2:first-child{margin-top:0}.legal p{color:var(--muted);font-size:.84rem}.legal a{color:var(--accent-dk);text-decoration:underline}
/* Footer — COLOPHON STYLE (centered, small) */
.site-footer{padding:40px 0 20px;border-top:1px solid var(--border);text-align:center}
.site-footer p{color:var(--muted);font-size:.7rem;max-width:400px;margin:0 auto 4px}
.ft-links{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin:14px 0}
.ft-links a{font-family:var(--font-h);color:var(--muted);font-size:.54rem;text-transform:uppercase;letter-spacing:1.5px}.ft-links a:hover{color:var(--accent)}
.ft-bottom{font-size:.56rem;color:var(--border-dk);margin-top:14px}
.cookie-banner{position:fixed;bottom:0;left:var(--sidebar-w);right:0;z-index:99;background:var(--surface);border-top:1px solid var(--border);padding:14px 32px;display:none;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;font-size:.76rem;color:var(--muted)}
@media(max-width:900px){.cookie-banner{left:0}}
.cookie-banner.show{display:flex}.cookie-banner p{margin:0;max-width:400px}.cookie-banner a{color:var(--accent);text-decoration:underline}
.cb-btns{display:flex;gap:6px}.cb-btn{padding:8px 18px;font-family:var(--font-h);font-weight:600;font-size:.56rem;text-transform:uppercase;letter-spacing:2px;border:1px solid var(--border);background:transparent;cursor:pointer;transition:all var(--tr);color:var(--text)}
.cb-accept{border-color:var(--accent);background:var(--accent);color:var(--white)}.cb-decline:hover{border-color:var(--accent)}
.res-page{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:80px 40px}.res-icon{font-size:2.4rem;margin-bottom:14px}.res-page h1{margin-bottom:8px}.res-page p{color:var(--muted);max-width:380px;margin:0 auto 20px}
.fade-in{opacity:0;transform:translateY(10px);transition:opacity .6s ease,transform .6s ease}.fade-in.visible{opacity:1;transform:translateY(0)}
.text-center{text-align:center}.mt-4{margin-top:24px}
.alert{padding:10px 12px;margin-bottom:12px;font-size:.82rem;border:1px solid var(--border)}
.alert-error{border-color:var(--accent);color:var(--accent-dk)}.alert-success{border-color:#059669;color:#059669}
