/* PyEncoder site — shared stylesheet */
@font-face{
  font-family:'Noto Color Emoji';
  src:url('/fonts/NotoColorEmoji.v2.woff2') format('woff2');
  font-display:swap;
}
:root{
  --teal:#16c3c9; --teal-d:#0b8e93; --ink:#0d0f12; --ink2:#14171b; --ink3:#1a1e23;
  --bg:#0e1013; --panel:#15181c; --fg:#e8eef0; --muted:#9aa4aa; --muted2:#6b757b;
  --border:#23282e; --accent:#16c3c9; --good:#5fe0a0;
  --maxw:1140px;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif,'Noto Color Emoji';
  background:var(--bg); color:var(--fg); line-height:1.6; font-size:16px;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--teal); text-decoration:none;}
a:hover{text-decoration:underline;}
img{max-width:100%; display:block;}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px;}

/* ---- Header ---- */
.site-hdr{
  position:sticky; top:0; z-index:50;
  background:rgba(13,15,18,.92); backdrop-filter:blur(8px);
  border-bottom:1px solid var(--border);
}
.site-hdr .wrap{display:flex; align-items:center; gap:24px; height:64px;}
.brand{display:flex; align-items:center; gap:10px; font-weight:700; font-size:20px; color:var(--fg);}
.brand:hover{text-decoration:none;}
.brand img{height:34px; width:auto;}
.brand b{color:var(--teal);}
.nav{display:flex; gap:22px; margin-left:auto; align-items:center;}
.nav a{color:var(--muted); font-size:15px; font-weight:500;}
.nav a:hover,.nav a.active{color:var(--fg); text-decoration:none;}
.nav .btn{margin-left:6px;}
.btn{
  display:inline-block; background:linear-gradient(90deg,var(--teal),var(--teal-d));
  color:#06222a; font-weight:700; padding:9px 18px; border-radius:8px; font-size:15px;
}
.btn:hover{filter:brightness(1.08); text-decoration:none;}
.btn.ghost{background:transparent; color:var(--teal); border:1px solid var(--teal); }
.menu-toggle{display:none; margin-left:auto; background:none; border:0; color:var(--fg); font-size:24px; cursor:pointer;}

/* ---- Hero ---- */
.hero{
  background:radial-gradient(1200px 500px at 70% -10%,rgba(22,195,201,.12),transparent 60%),
             linear-gradient(180deg,#0e1013,#0b0d10);
  border-bottom:1px solid var(--border);
  padding:72px 0 56px;
}
.hero .wrap{display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center;}
.hero h1{font-size:54px; line-height:1.08; margin:0 0 18px; letter-spacing:-1px;}
.hero h1 .accent{color:var(--teal);}
.hero p.lead{font-size:20px; color:var(--muted); margin:0 0 28px; max-width:540px;}
.hero .cta{display:flex; gap:14px; flex-wrap:wrap;}
.hero-shot{border:1px solid var(--border); border-radius:12px; overflow:hidden; box-shadow:0 24px 60px rgba(0,0,0,.5);}
.eyebrow{display:inline-block; font-size:13px; letter-spacing:1.5px; text-transform:uppercase; color:var(--teal); font-weight:700; margin-bottom:14px;}

/* ---- Sections ---- */
section{padding:64px 0;}
section.alt{background:var(--ink2); border-top:1px solid var(--border); border-bottom:1px solid var(--border);}
.section-head{text-align:center; max-width:680px; margin:0 auto 44px;}
.section-head h2{font-size:34px; margin:0 0 12px; letter-spacing:-.5px;}
.section-head p{font-size:18px; color:var(--muted); margin:0;}

/* ---- Feature grid ---- */
.grid{display:grid; gap:22px;}
.grid.cols-3{grid-template-columns:repeat(3,1fr);}
.grid.cols-2{grid-template-columns:repeat(2,1fr);}
.card{
  background:var(--panel); border:1px solid var(--border); border-radius:12px; padding:26px;
}
.card .ico{font-size:30px; margin-bottom:14px; line-height:1;}
.card h3{margin:0 0 8px; font-size:19px;}
.card p{margin:0; color:var(--muted); font-size:15px;}

/* ---- Split feature rows ---- */
.feature-row{display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; margin:0 0 56px;}
.feature-row:nth-child(even) .ftext{order:2;}
.feature-row h3{font-size:26px; margin:0 0 14px;}
.feature-row p{color:var(--muted); font-size:17px; margin:0 0 16px;}
.feature-row ul{margin:0; padding-left:20px; color:var(--muted);}
.feature-row li{margin-bottom:8px;}
.feature-row .shot{border:1px solid var(--border); border-radius:12px; overflow:hidden; box-shadow:0 16px 40px rgba(0,0,0,.45);}

/* ---- Stats ---- */
.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center;}
.stats .n{font-size:40px; font-weight:800; color:var(--teal);}
.stats .l{color:var(--muted); font-size:15px;}

/* ---- Code / pre ---- */
pre,code{font-family:'Cascadia Code',Consolas,'SF Mono',monospace;}
pre{
  background:#0a0c0f; border:1px solid var(--border); border-radius:10px; padding:18px 20px;
  overflow:auto; font-size:14px; color:#cdd6da; line-height:1.7;
}
code{background:#1a1e23; padding:2px 6px; border-radius:4px; font-size:.92em; color:#7fe3e6;}
pre code{background:none; padding:0; color:inherit;}
.cmt{color:#5d6a70;}
.kw{color:var(--teal);}

/* ---- Tables ---- */
table{border-collapse:collapse; width:100%; margin:18px 0; font-size:15px;}
th,td{border:1px solid var(--border); padding:10px 14px; text-align:left;}
th{background:var(--ink3); color:var(--fg);}
td{color:var(--muted);}

/* ---- Steps ---- */
.steps{counter-reset:step; max-width:760px; margin:0 auto;}
.step{position:relative; padding:0 0 28px 60px; border-left:2px solid var(--border); margin-left:18px;}
.step:last-child{border-left-color:transparent;}
.step::before{
  counter-increment:step; content:counter(step);
  position:absolute; left:-19px; top:-4px; width:36px; height:36px; border-radius:50%;
  background:var(--teal); color:#06222a; font-weight:800; display:flex; align-items:center; justify-content:center;
}
.step h3{margin:0 0 6px; font-size:19px;}
.step p{margin:0; color:var(--muted);}

/* ---- Changelog ---- */
.release{border-left:2px solid var(--border); padding:0 0 28px 24px; margin-left:8px; position:relative;}
.release::before{content:''; position:absolute; left:-7px; top:4px; width:12px; height:12px; border-radius:50%; background:var(--teal);}
.release .ver{font-size:20px; font-weight:700;}
.release .date{color:var(--muted2); font-size:14px; margin-left:8px;}
.release ul{color:var(--muted); margin:10px 0 0; padding-left:20px;}
.tag{display:inline-block; font-size:11px; font-weight:700; padding:2px 8px; border-radius:20px; margin-left:8px; vertical-align:middle;}
.tag.new{background:#16352b; color:var(--good);}
.tag.fix{background:#33291a; color:#e0a85f;}

/* ---- CTA band ---- */
.cta-band{background:linear-gradient(90deg,#0c2a2c,#0a1c22); border-top:1px solid var(--border); border-bottom:1px solid var(--border); text-align:center; padding:64px 0;}
.cta-band h2{font-size:32px; margin:0 0 14px;}
.cta-band p{color:var(--muted); font-size:18px; margin:0 0 26px;}

/* ---- Footer ---- */
.site-ftr{background:#0a0c0f; border-top:1px solid var(--border); padding:48px 0 32px; margin-top:0;}
.site-ftr .cols{display:grid; grid-template-columns:2fr 1fr 1fr 1.4fr; gap:32px;}
.site-ftr h4{font-size:14px; text-transform:uppercase; letter-spacing:1px; color:var(--muted2); margin:0 0 14px;}
.site-ftr a{color:var(--muted); display:block; margin-bottom:8px; font-size:15px;}
.site-ftr a:hover{color:var(--fg);}
.site-ftr .fbrand{display:flex; align-items:center; gap:10px; font-weight:700; font-size:18px; margin-bottom:12px; color:var(--fg);}
.site-ftr .fbrand img{height:30px;}
.site-ftr .blurb{color:var(--muted); font-size:14px; max-width:300px;}
.site-ftr .contact{color:var(--muted); font-size:15px;}
.site-ftr .contact a{display:inline; margin:0;}
.foot-bottom{border-top:1px solid var(--border); margin-top:32px; padding-top:20px; text-align:center; color:var(--muted2); font-size:13px;}
.foot-bottom a{color:var(--muted2); margin:0 6px;}

/* ---- Legal page content (privacy/terms reuse) ---- */
.legal main{max-width:820px;}

/* ---- Responsive ---- */
@media (max-width:900px){
  .hero .wrap{grid-template-columns:1fr; gap:32px;}
  .hero h1{font-size:42px;}
  .feature-row{grid-template-columns:1fr; gap:24px;}
  .feature-row:nth-child(even) .ftext{order:0;}
  .grid.cols-3,.grid.cols-2{grid-template-columns:1fr;}
  .stats{grid-template-columns:repeat(2,1fr); gap:32px;}
  .site-ftr .cols{grid-template-columns:1fr 1fr;}
  .nav{display:none; position:absolute; top:64px; left:0; right:0; flex-direction:column; gap:0;
       background:var(--ink); border-bottom:1px solid var(--border); padding:8px 0;}
  .nav.open{display:flex;}
  .nav a{padding:12px 24px; width:100%;}
  .nav .btn{margin:10px 24px; text-align:center;}
  .menu-toggle{display:block;}
}
@media (max-width:560px){
  .stats{grid-template-columns:1fr 1fr;}
  .site-ftr .cols{grid-template-columns:1fr;}
  .hero h1{font-size:34px;}
}
