/*
Theme Name: Projector Cam Cinematic
Theme URI: https://projectorcam.com/
Description: Dark cinematic home-theater theme for Projector Cam. Full-bleed hero, overlay-title cards, amber accent, Space Grotesk + Inter. Bespoke, no framework.
Author: Projector Cam
Version: 1.0
License: GPL-2.0-or-later
Text Domain: pcam
*/

/* ============ TOKENS ============ */
:root{
  --bg:#07080c;            /* near-black */
  --bg2:#0d0f16;           /* panel */
  --surface:#13161f;       /* card surface */
  --surface2:#191d29;
  --ink:#eef0f5;           /* primary text */
  --muted:#9aa0b0;         /* secondary text */
  --faint:#6b7080;
  --line:#262b38;          /* hairline */
  --accent:#e8590c;        /* amber */
  --accent-2:#ff8a3d;      /* lighter amber */
  --accent-dk:#c24809;
  --glow:rgba(232,89,12,.35);
  --hfont:"Space Grotesk", ui-sans-serif, system-ui, sans-serif;
  --bfont:"Inter", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --maxw:1180px;
  --readw:760px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--bfont);font-size:17px;line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent-2);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--hfont);font-weight:700;line-height:1.15;letter-spacing:-.01em;color:#fff}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* ============ HEADER ============ */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(7,8,12,.82);backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line);
}
.site-header .hd{
  max-width:var(--maxw);margin:0 auto;padding:14px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
}
.brand{display:flex;align-items:center;gap:11px;color:#fff;font-family:var(--hfont);
  font-weight:700;font-size:1.18rem;letter-spacing:.01em;text-transform:uppercase}
.brand:hover{text-decoration:none}
.brand-mark{width:18px;height:18px;border-radius:50%;
  background:radial-gradient(circle at 50% 50%,var(--accent-2),var(--accent) 55%,transparent 72%);
  box-shadow:0 0 18px var(--glow);flex:0 0 auto}
.brand-txt{display:inline-block}
.nav .menu{list-style:none;display:flex;gap:6px;margin:0;padding:0}
.nav .menu a{
  display:block;color:var(--muted);font-family:var(--hfont);font-weight:500;
  font-size:.84rem;letter-spacing:.04em;text-transform:uppercase;
  padding:8px 13px;border-radius:6px;
}
.nav .menu a:hover{color:#fff;background:var(--surface);text-decoration:none}
.nav .menu .current-menu-item a,.nav .menu .current_page_item a{color:var(--accent-2)}

.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;gap:5px;flex-direction:column}
.nav-toggle span{width:24px;height:2px;background:var(--ink);display:block}

/* ============ HERO (full-bleed) ============ */
.hero{
  position:relative;width:100%;
  min-height:clamp(360px,52vh,560px);
  display:flex;align-items:flex-end;
  background-color:var(--bg2);
  background-size:cover;background-position:center;
  border-bottom:1px solid var(--line);
}
.hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,var(--bg) 100%);pointer-events:none}
.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;
  width:100%;padding:0 22px 54px}
.hero-kicker{display:inline-block;font-family:var(--hfont);font-weight:600;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-2);
  margin-bottom:14px;padding:5px 12px;border:1px solid var(--accent);border-radius:50px;
  background:rgba(232,89,12,.08)}
.hero h1{font-size:clamp(2.3rem,6vw,4.2rem);margin:0 0 .25em;text-shadow:0 4px 40px rgba(0,0,0,.6)}
.hero p{max-width:620px;color:#d6d9e2;font-size:1.1rem;margin:0}

/* ============ CARD GRID (overlay-title) ============ */
.page-head{padding:34px 0 8px}
.page-head h1{font-size:clamp(1.8rem,4vw,2.6rem);margin:0 0 .2em}
.pgrid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:22px;margin:34px 0 50px;
}
.pcard{position:relative;border-radius:14px;overflow:hidden;background:var(--surface);
  border:1px solid var(--line);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.pcard:hover{transform:translateY(-5px);border-color:var(--accent);
  box-shadow:0 18px 40px -18px rgba(0,0,0,.8),0 0 0 1px var(--accent)}
.pcard a{display:block;color:inherit}
.pcard a:hover{text-decoration:none}
.pcard-img{position:relative;aspect-ratio:16/10;background-size:cover;background-position:center;
  background-color:var(--surface2)}
.pcard-img:not(.has-img){display:flex;align-items:center;justify-content:center}
.pcard-img:not(.has-img) span{font-family:var(--hfont);color:var(--faint);font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;font-size:.8rem}
.pcard-img::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(7,8,12,0) 38%,rgba(7,8,12,.95) 100%)}
.pcard-overlay{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:18px 18px 17px}
.pcard-tag{display:inline-block;font-family:var(--hfont);font-weight:600;font-size:.66rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2);margin-bottom:7px}
.pcard-title{font-size:1.12rem;line-height:1.25;color:#fff;margin:0;
  text-shadow:0 2px 14px rgba(0,0,0,.7)}
.pcard:hover .pcard-title{color:var(--accent-2)}

.pager{margin:10px 0 56px;text-align:center}
.pager .nav-links a,.pager .nav-links span{display:inline-block;padding:8px 14px;margin:0 3px;
  border:1px solid var(--line);border-radius:7px;color:var(--ink);font-family:var(--hfont);font-size:.9rem}
.pager .nav-links .current{background:var(--accent);border-color:var(--accent);color:#fff}

/* ============ ARTICLE / .entry ============ */
.site-main{min-height:50vh}
.entry{max-width:var(--readw);margin:38px auto 30px}
.breadcrumb{font-family:var(--hfont);font-size:.78rem;letter-spacing:.03em;color:var(--faint);margin:0 0 1.2em}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--accent-2)}
.post-title{font-size:clamp(2rem,4.5vw,2.9rem);margin:0 0 .35em}
.meta-line{color:var(--muted);font-family:var(--hfont);font-size:.82rem;letter-spacing:.02em;margin-bottom:1.6em}
.entry-hero{width:100%;border-radius:14px;margin:0 0 1.8em;border:1px solid var(--line)}

.entry p{margin:0 0 1.25em;color:#dfe2ea}
.entry h2{font-size:1.7rem;margin:1.9em 0 .55em;padding-top:.2em;
  border-top:1px solid var(--line);padding-top:1.1em}
.entry h2:first-of-type{border-top:0;padding-top:0}
.entry h3{font-size:1.28rem;margin:1.5em 0 .45em;color:#fff}
.entry h2::before{content:"";display:inline-block;width:22px;height:3px;
  background:var(--accent);vertical-align:middle;margin-right:11px;border-radius:2px;
  box-shadow:0 0 12px var(--glow)}
.entry a{color:var(--accent-2);text-decoration:underline;text-decoration-color:rgba(255,138,61,.4);text-underline-offset:2px}
.entry a:hover{text-decoration-color:var(--accent-2)}
.entry strong{color:#fff}

/* lists with custom amber bullets (NOT default discs) */
.entry ul{list-style:none;padding-left:1.6em;margin:0 0 1.25em}
.entry ul>li{position:relative;padding-left:.2em;margin:0 0 .55em;color:#dfe2ea}
.entry ul>li::before{content:"";position:absolute;left:-1.1em;top:.66em;
  width:9px;height:9px;border-radius:2px;transform:rotate(45deg);
  background:var(--accent);box-shadow:0 0 10px var(--glow)}
.entry ol{padding-left:1.5em;margin:0 0 1.25em}
.entry ol>li{margin:0 0 .55em;color:#dfe2ea}
.entry ol>li::marker{color:var(--accent-2);font-weight:700;font-family:var(--hfont)}

.entry blockquote{margin:1.5em 0;padding:.4em 1.2em;border-left:3px solid var(--accent);
  background:var(--surface);color:#cfd3de;border-radius:0 8px 8px 0;font-style:italic}

/* ============ TABLES ============ */
.pcam-tablewrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:1.6em 0;
  border:1px solid var(--line);border-radius:12px}
.entry table{border-collapse:collapse;width:100%;min-width:560px;margin:0;font-size:.95rem;background:var(--surface)}
.entry th,.entry td{border-bottom:1px solid var(--line);padding:11px 13px;text-align:left;vertical-align:top}
.entry th{background:var(--surface2);color:#fff;font-family:var(--hfont);font-weight:600;
  letter-spacing:.02em;white-space:nowrap;border-bottom:2px solid var(--accent)}
.entry tbody tr:nth-child(even){background:rgba(255,255,255,.022)}
.entry tbody tr:hover{background:rgba(232,89,12,.06)}

/* ============ DISCLOSURE BOX (.cmpc-disc) ============ */
.cmpc-disc{font-size:.84rem;color:var(--muted);background:var(--surface);
  border:1px solid var(--line);border-left:3px solid var(--accent);
  padding:.85em 1.15em;margin:0 0 1.8em;border-radius:0 10px 10px 0}
.cmpc-disc a{color:var(--accent-2)}

/* ============ CTA BUTTON (.cta-amz) — gradient, glow, sharp-edged ============ */
.cta-amz{
  display:inline-block;margin:.4em 0;padding:14px 26px;
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-2) 100%);
  color:#fff!important;font-family:var(--hfont);font-weight:700;font-size:1rem;
  letter-spacing:.02em;text-transform:uppercase;text-decoration:none!important;
  border-radius:8px;border:0;cursor:pointer;
  box-shadow:0 8px 26px -8px var(--glow),inset 0 1px 0 rgba(255,255,255,.25);
  transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;
}
.cta-amz:hover{transform:translateY(-2px);filter:brightness(1.06);
  box-shadow:0 14px 34px -8px var(--glow),inset 0 1px 0 rgba(255,255,255,.3)}
.cta-amz:active{transform:translateY(0)}
.cta-amz span{font-weight:500;opacity:.9;font-size:.8rem;margin-left:6px;text-transform:none}

/* ============ RELATED ============ */
.related{max-width:var(--maxw);margin:50px auto 0;padding:0 0;border-top:1px solid var(--line)}
.related>h2{font-size:1.5rem;margin:1.6em 0 .2em}

/* ============ FOOTER ============ */
.site-footer{background:var(--bg2);border-top:1px solid var(--line);margin-top:60px;
  padding:46px 0 40px;color:var(--muted)}
.foot-brand{display:flex;align-items:center;gap:10px;font-family:var(--hfont);
  font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.02em;margin-bottom:18px}
.foot-links{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:18px}
.foot-links a{color:var(--muted);font-size:.9rem;font-family:var(--hfont);font-weight:500}
.foot-links a:hover{color:var(--accent-2);text-decoration:none}
.foot-disc{font-size:.82rem;color:var(--faint);line-height:1.6;margin:0;max-width:760px}

/* ============ RESPONSIVE ============ */
@media (max-width:880px){
  .nav-toggle{display:flex}
  .nav{position:absolute;top:100%;left:0;right:0;background:var(--bg2);
    border-bottom:1px solid var(--line);padding:10px 22px 18px;
    display:none}
  .site-header.open .nav{display:block}
  .nav .menu{flex-direction:column;gap:2px}
  .nav .menu a{padding:11px 12px;font-size:.95rem}
  .site-header .hd{position:relative}
}
@media (max-width:680px){
  body{font-size:16px}
  .pgrid{grid-template-columns:1fr;gap:18px}
  .hero{min-height:46vh}
  .hero-inner{padding-bottom:36px}
  .entry table{font-size:.9rem}
  .entry th,.entry td{padding:9px 10px}
  .cta-amz{display:block;text-align:center}
}
