/* FrillyBits.net — minimal, playful, and responsive */
:root{
  --bg:#0ea84a;            /* pulled from banner */
  --bg-2:#0b8a3d;
  --ink:#0b1b12;
  --ink-muted:#274a36;
  --chip:#111;             /* dark chip color */
  --accent:#ffd12e;        /* golden trace */
  --paper:#f7fff9;
  --card:#ffffff;
  --shadow: 0 8px 30px rgb(0 0 0 / 0.08);
  --radius: 16px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font: 16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Inter,Arial,sans-serif;
  color:var(--ink);
  background:linear-gradient(180deg,var(--paper),#f4fff7);
}

.container{width:min(1100px,92vw);margin:auto}

.visually-hidden{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

/* Header */
.site-header{
  position:sticky;top:0;z-index:10;
  background:#fff; box-shadow:var(--shadow);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.brand{
  display:flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--ink);
  font-weight:800;letter-spacing:.3px
}
.brand-chip{width:14px;height:14px;border-radius:4px;background:var(--chip);display:grid;place-items:center;color:#fff;font-size:.7rem}
.brand-text{font-size:1.25rem}
.brand-text .dot{color:var(--accent)}

.nav{display:flex;gap:1rem;align-items:center}
.nav a{color:var(--ink);text-decoration:none;padding:.5rem .7rem;border-radius:10px}
.nav a:hover{background:#f1fff5}
.nav .cta{background:var(--ink);color:#fff}
.nav .cta:hover{background:#000}

.nav-toggle{display:none;background:none;border:none;font-size:1.4rem}

/* Hero */
.hero{position:relative;overflow:hidden;background:var(--bg)}
.hero-banner{width:100%;height:180px;object-fit:cover;display:block;mix-blend:normal}
.hero-content{
  color:#fff; padding:36px 0 50px;
}
.hero h1{font-size: clamp(28px, 5vw, 54px);line-height:1.05;margin:0 0 .4rem}
.hero p{max-width:60ch;margin:.2rem 0 1.2rem;color:#eaffea}
.actions{display:flex;gap:.7rem;flex-wrap:wrap}

.btn{display:inline-block;border:1px solid var(--ink);padding:.7rem 1rem;border-radius:12px;text-decoration:none;color:var(--ink);font-weight:600;box-shadow:var(--shadow)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#3a3200}
.btn.ghost{background:transparent}
.btn.small{padding:.45rem .75rem;font-size:.9rem}

/* Sections */
.section{padding:64px 0}
.section.alt{background:linear-gradient(180deg,#f6fff9,#f2fff7)}
h2{font-size:clamp(22px,3.4vw,36px);margin:0 0 1rem}
h3{margin:0 0 .5rem}
p{margin:.4rem 0 1rem}

/* Layout */
.grid-2{display:grid;grid-template-columns:1.2fr .8fr;gap:28px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

.card{
  background:var(--card);
  border:1px solid #e4f6ea;
  border-radius:var(--radius);
  padding:18px;
  box-shadow:var(--shadow);
}
.card.code pre{
  margin:0; overflow:auto; background:#0e1a12; color:#d6ffe8;
  padding:14px;border-radius:12px;border:1px solid #1f3f2c;
}

/* Lists */
.checklist{padding-left:1.2rem}
.checklist li{margin:.3rem 0}
.bullets{padding-left:1.2rem}
.steps{padding-left:1.25rem}
.steps li{margin:.25rem 0}

/* Products */
.product{position:relative}
.product-badge{
  position:absolute;right:12px;top:12px;background:var(--accent);
  color:#3a3200;border-radius:999px;padding:.2rem .6rem;font-size:.75rem;font-weight:700
}

/* Signup */
.signup{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.5rem}
.signup input{
  flex:1 1 260px;padding:.8rem .9rem;border-radius:12px;border:1px solid #cfeedd;outline:none
}
.signup input:focus{border-color:var(--bg-2);box-shadow:0 0 0 3px #d7f8e5}

/* Footer */
.site-footer{padding:26px 0;border-top:1px solid #e4f6ea;background:#fcfffd;color:var(--ink-muted)}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.footer-inner a{color:var(--ink);text-decoration:none}

/* Responsive */
@media (max-width: 880px){
  .grid-2{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr 1fr}
  .nav{display:none}
  .nav-toggle{display:block}
  .site-header.open .nav{display:flex;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:10px;border-bottom:1px solid #e8f4ec}
  .site-header.open .nav a{padding:12px 16px}
}
@media (max-width: 560px){
  .cards{grid-template-columns:1fr}
  .hero-banner{height:140px}
}
