/*
Theme Name: FunnelST Medium v2.7.1
Theme URI: https://funnel.st/
Author: Blackcedar
Description: Medium-style singles + Hacker News list. Mobile off-canvas menu. Customizer for colors, fonts, container, logo, brand size, and Typography Scale.
Version: 2.7.1-newsletter-controls
Text Domain: funnelst-medium
*/
:root { --bg:#f6f6ef; --text:#111111; --link:#0f766e; --accent:#ff6600; --container:880px; --base:18px; --lh:1.7; --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,Helvetica,Arial,sans-serif; --logo-h:34px; --brand-size:22px; --h1:40px; --h2:32px; --h3:26px; --h4:22px; --content:20px }
html{box-sizing:border-box}*,*:before,*:after{box-sizing:inherit}
body{margin:0;background:var(--bg);color:var(--text);font:normal var(--base)/var(--lh) var(--font)}
a{color:var(--link);text-decoration:none}a:hover{text-decoration:underline}
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 16px}
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.96);border-bottom:1px solid #eee;backdrop-filter:saturate(180%) blur(8px)}
.header-inner{display:flex;align-items:center;justify-content:flex-start;min-height:60px;gap:12px}
.brand{display:flex;gap:10px;align-items:center;font-weight:800;font-size:var(--brand-size);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brand img{height:var(--logo-h);width:auto}
.mobile-toggle{display:none;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:10px 12px;line-height:0;box-shadow:0 2px 8px rgba(0,0,0,.05);cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.mobile-toggle:focus-visible{outline:2px solid var(--link);outline-offset:2px}
.mobile-toggle span{display:block;width:22px;height:2px;background:#333;margin:4px 0}
.primary-nav{display:flex;align-items:center;gap:14px;margin-left:auto}
.primary-nav ul.menu{list-style:none;padding:0;margin:0;display:flex;gap:10px;flex-wrap:wrap}
.primary-nav li{display:inline-flex}
.primary-nav .menu a{background:#eee;color:var(--link);padding:8px 12px;border-radius:10px;border:1px solid #e5e7eb;text-decoration:none;display:inline-flex;align-items:center;line-height:1}
.primary-nav .menu a:hover{background:#e7e7e7;border-color:#d1d5db;color:var(--link)}
.primary-nav .menu .current-menu-item>a,.primary-nav .menu .current_page_item>a{border-color:var(--accent);box-shadow:0 0 0 2px rgba(255,102,0,.08) inset}
.cta-btn{padding:8px 12px;border-radius:9999px;border:1px solid var(--link);background:var(--link);color:#fff;font-weight:600;white-space:nowrap}
.nav-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.35);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:1000}
.drawer{position:fixed;top:0;right:-84%;height:100%;width:84%;background:#fff;border-left:1px solid #e5e7eb;box-shadow:-10px 0 24px rgba(0,0,0,.08);z-index:1001;display:flex;flex-direction:column;padding:16px;transition:right .25s ease}
.drawer .menu{display:flex;flex-direction:column;gap:10px;margin:0;padding:12px 0 0 0;list-style:none}
.drawer .menu a{background:#eee;color:var(--link);padding:12px 14px;border-radius:12px;border:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;text-decoration:none}
.drawer .menu a:hover{background:#e7e7e7;color:var(--link);border-color:#d1d5db}
.drawer-header{display:flex;align-items:center;justify-content:space-between;gap:8px}
.drawer-title{font-weight:800;font-size:18px}
.drawer-close{background:transparent;border:1px solid #e5e7eb;border-radius:10px;padding:8px 10px;cursor:pointer}
body.drawer-open{overflow:hidden}
body.drawer-open .nav-backdrop{opacity:1;pointer-events:auto}
body.drawer-open .drawer{right:0}
.hn-wrap{background:var(--bg);padding:12px 0 24px}
.hn-table{width:100%;border-collapse:separate;border-spacing:0 8px}
.hn-idx{width:32px;color:#777;text-align:right;padding-right:8px;vertical-align:top}
.hn-title{font-weight:600}.hn-source{color:#777;margin-left:6px}
.hn-meta{color:#666;font-size:14px;margin-top:4px}.hn-meta .author-link{text-decoration:underline}
.more{display:block;padding:12px 0 24px}
.prose{font-size:var(--content)}.prose p{margin:1em 0}
.prose h1{font-size:var(--h1);line-height:1.2;margin:.6em 0 .3em}
.prose h2{font-size:var(--h2);line-height:1.25;margin:.8em 0 .4em}
.prose h3{font-size:var(--h3);line-height:1.3;margin:1em 0 .5em}
.prose h4{font-size:var(--h4);line-height:1.35;margin:1.2em 0 .6em}
.inline-subscribe{border:1px solid #e5e7eb;background:#f9fafb;padding:16px;border-radius:12px;margin:16px 0}
.subscribe-row{display:flex;gap:8px}
.subscribe-row input[type=email]{flex:1;padding:12px 14px;border:1px solid #d1d5db;border-radius:10px;font-size:16px}
.subscribe-row button{padding:12px 16px;border-radius:10px;border:1px solid var(--link);background:var(--link);color:#fff;font-weight:700}
.site-footer{border-top:2px solid var(--accent);margin-top:24px}
.hn-footer{text-align:center;padding:14px 0;font-size:14px;color:#555}
.hn-footer .links a{color:#555;padding:0 6px}.hn-footer .message{margin-top:6px;color:#666}
.footer-search{margin-top:10px;display:flex;gap:8px;justify-content:center}
.footer-search input[type=search]{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;min-width:220px}
.footer-search button{padding:10px 12px;border-radius:8px;border:1px solid var(--link);background:var(--link);color:#fff;font-weight:700}
@media (max-width:900px){:root{--container:720px}.brand{font-size:calc(var(--brand-size) - 2px)}.hn-meta{font-size:13px}}
@media (max-width:720px){:root{--container:100%;--h1:34px;--h2:28px;--h3:22px;--content:19px}.mobile-toggle{display:inline-block;margin-left:auto}.primary-nav{display:none}.hn-idx{width:24px;padding-right:6px}.container{padding:0 12px}}
@media (max-width:420px){:root{--h1:30px;--h2:24px;--h3:20px;--content:18px}.brand{font-size:calc(var(--brand-size) - 3px)}.footer-search input[type=search]{min-width:0;width:100%}}
