/* ===========================================================
   BUGG  ·  bugg.kymafoundry.com
   Warm "case file" aesthetic — paper, ink, BUGG teal + rust.
   Vanilla CSS. No framework.
   =========================================================== */

:root{
  --ink:#241a12; --ink-soft:#5b4b3c;
  --paper:#f6efe3; --paper-2:#efe5d3; --card:#fffaf1;
  --teal:#007FA3; --teal-d:#0a6076;
  --rust:#b5302a; --rust-d:#8f231e;
  --amber:#d98a2b;
  --line:#ddccae;
  --shadow:0 18px 40px -18px rgba(58,40,20,.45);
  --r:16px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; color:var(--ink);
  font-family:"Hanken Grotesk",system-ui,-apple-system,"Segoe UI",sans-serif;
  font-size:17px; line-height:1.6;
  background:
    radial-gradient(900px 500px at 85% -10%, #fff7ea 0%, transparent 60%),
    radial-gradient(700px 500px at 0% 100%, #f0e3cd 0%, transparent 55%),
    var(--paper);
  background-attachment:fixed;
}
/* faint dot-grid, like graph paper on a desk */
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:0;
  background-image:radial-gradient(rgba(120,90,50,.10) 1px, transparent 1px);
  background-size:26px 26px; opacity:.5;
}
.wrap{max-width:1080px; margin:0 auto; padding:0 24px; position:relative; z-index:1;}

h1,h2,h3{font-family:"Fraunces",Georgia,serif; line-height:1.08; margin:0; letter-spacing:-.01em;}
a{color:var(--teal-d); text-underline-offset:3px;}

/* ---------- nav ---------- */
nav{
  position:sticky; top:0; z-index:50; backdrop-filter:saturate(1.2) blur(6px);
  background:rgba(246,239,227,.82); border-bottom:1px solid var(--line);
}
nav .wrap{display:flex; align-items:center; gap:14px; padding:12px 24px;}
.brand{display:flex; align-items:center; gap:11px; text-decoration:none; color:var(--ink);}
.brand img{width:58px; height:58px; object-fit:contain;}
.brand .name{font-family:"Fraunces",serif; font-weight:900; font-size:23px; letter-spacing:.5px; line-height:1;}
.brand .sub{font-size:11px; color:var(--ink-soft); letter-spacing:.04em; margin-top:2px;}
nav .spacer{flex:1;}
.nav-cta{
  background:var(--rust); color:#fff; text-decoration:none; font-weight:800; font-size:14px;
  padding:9px 16px; border-radius:10px; transition:filter .15s, transform .1s;
}
.nav-cta:hover{filter:brightness(1.08);} .nav-cta:active{transform:scale(.98);}

/* ---------- hero ---------- */
.hero{padding:56px 0 28px;}
.hero .wrap{display:grid; grid-template-columns:1.15fr .95fr; gap:36px; align-items:center;}
.stamp{
  display:inline-flex; align-items:center; gap:7px; transform:rotate(-2deg);
  border:2px solid var(--rust); color:var(--rust); border-radius:8px;
  font-weight:800; font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  padding:6px 11px; margin-bottom:18px;
}
.hero h1{font-size:clamp(38px,6vw,62px); font-weight:900;}
.hero h1 .pop{color:var(--rust); position:relative; white-space:nowrap;}
.hero h1 .pop::after{
  content:""; position:absolute; left:0; right:0; bottom:6px; height:10px;
  background:rgba(217,138,43,.45); border-radius:6px; z-index:-1; transform:rotate(-1deg);
}
.hero p.lede{font-size:19px; color:var(--ink-soft); margin:18px 0 26px; max-width:42ch;}
.hero .cta-row{display:flex; gap:14px; flex-wrap:wrap; align-items:center;}
.btn{
  display:inline-block; text-decoration:none; font-weight:800; border-radius:12px;
  padding:13px 22px; transition:filter .15s, transform .1s, box-shadow .15s; cursor:pointer; border:none; font:inherit; font-weight:800;
}
.btn-primary{background:var(--teal); color:#fff; box-shadow:0 10px 22px -10px rgba(0,127,163,.7);}
.btn-primary:hover{filter:brightness(1.07);} .btn-primary:active{transform:translateY(1px);}
.btn-ghost{background:transparent; color:var(--ink); border:2px solid var(--line);}
.btn-ghost:hover{border-color:var(--teal); color:var(--teal-d);}
.hero-art{position:relative; text-align:center;}
.hero-art img{width:100%; max-width:430px; filter:drop-shadow(0 24px 30px rgba(60,40,20,.28));}
.hint{
  display:inline-flex; align-items:center; gap:8px; margin-top:10px;
  font-size:13px; color:var(--ink-soft); font-style:italic;
}

/* ---------- section frame ---------- */
section.block{padding:54px 0;}
.eyebrow{font-weight:800; letter-spacing:.16em; text-transform:uppercase; font-size:12px; color:var(--teal-d);}
.block h2{font-size:clamp(28px,4vw,40px); font-weight:900; margin:8px 0 6px;}
.block .sub{color:var(--ink-soft); max-width:54ch; margin-bottom:30px;}

/* ---------- how it works ---------- */
.steps{display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
.step{
  background:var(--card); border:1px solid var(--line); border-radius:var(--r);
  padding:26px 22px; box-shadow:var(--shadow); position:relative;
}
.step .n{
  position:absolute; top:-16px; left:22px; width:34px; height:34px; border-radius:50%;
  background:var(--teal); color:#fff; font-family:"Fraunces",serif; font-weight:900;
  display:flex; align-items:center; justify-content:center; font-size:17px; box-shadow:0 6px 14px -6px rgba(0,127,163,.8);
}
.step h3{font-size:20px; margin:10px 0 8px; font-weight:800;}
.step p{margin:0; color:var(--ink-soft); font-size:15.5px;}
.step .ic{font-size:26px; line-height:1;}

/* ---------- portfolio strip ---------- */
.watch{background:linear-gradient(135deg,var(--teal) 0%, var(--teal-d) 100%); color:#fff; border-radius:22px; padding:40px 34px; box-shadow:var(--shadow);}
.watch h2{color:#fff;}
.watch .sub{color:rgba(255,255,255,.85);}
.chips{display:flex; flex-wrap:wrap; gap:12px; margin-top:8px;}
.chip{
  background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.3);
  color:#fff; font-weight:700; font-size:14px; padding:9px 15px; border-radius:999px;
}

/* ---------- dogfood callout ---------- */
.dogfood{
  background:var(--card); border:2px dashed var(--rust); border-radius:var(--r);
  padding:30px 28px; text-align:center; box-shadow:var(--shadow);
}
.dogfood h2{color:var(--rust); margin-bottom:6px;}
.dogfood p{color:var(--ink-soft); margin:0 auto; max-width:50ch;}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line); margin-top:30px; padding:34px 0 50px;}
footer .wrap{display:flex; align-items:center; gap:14px; flex-wrap:wrap;}
footer img{width:46px; height:46px;}
footer .name{font-family:"Fraunces",serif; font-weight:900; font-size:18px;}
footer small{color:var(--ink-soft);}
footer .spacer{flex:1;}

/* ---------- entrance animation ---------- */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0; transform:translateY(14px); animation:rise .7s ease forwards;}
  .d1{animation-delay:.05s;} .d2{animation-delay:.15s;} .d3{animation-delay:.28s;} .d4{animation-delay:.4s;}
  @keyframes rise{to{opacity:1; transform:none;}}
}

/* ---------- responsive ---------- */
@media (max-width:820px){
  .hero .wrap{grid-template-columns:1fr; text-align:center;}
  .hero p.lede{margin-left:auto; margin-right:auto;}
  .hero .cta-row{justify-content:center;}
  .hero-art{order:-1;}
  .hero-art img{max-width:300px;}
  .steps{grid-template-columns:1fr;}
  .stamp{margin-left:auto; margin-right:auto;}
}

/* ===========================================================
   ADMIN CONSOLE  (admin.html)
   =========================================================== */
.admin-main{max-width:1180px; margin:0 auto; padding:24px;}
.gate{max-width:420px; margin:60px auto; background:var(--card); border:1px solid var(--line);
  border-radius:var(--r); padding:30px 28px; box-shadow:var(--shadow); text-align:center;}
.gate h2{font-size:24px; margin-bottom:6px;}
.gate p{color:var(--ink-soft); font-size:14px; margin:0 0 18px;}
.gate input{width:100%; padding:12px 14px; border:1.5px solid var(--line); border-radius:10px; font:inherit; margin-bottom:12px;}
.gate input:focus{outline:none; border-color:var(--teal); box-shadow:0 0 0 3px rgba(0,127,163,.15);}
.gate .err{color:var(--rust); font-size:13px; min-height:16px; margin-top:6px;}

.admin-bar{display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin:6px 0 18px;}
.admin-bar h2{font-size:26px; font-weight:900;}
.admin-bar .spacer{flex:1;}
.admin-bar select, .admin-bar button.mini{
  font:inherit; font-size:14px; padding:8px 12px; border-radius:9px; border:1.5px solid var(--line);
  background:var(--card); color:var(--ink); cursor:pointer;}
.admin-bar button.mini{background:var(--teal); color:#fff; border:none; font-weight:700;}
.logout{background:transparent !important; color:var(--ink-soft) !important; border:1.5px solid var(--line) !important;}

.addbug{background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:18px 20px; box-shadow:var(--shadow); margin-bottom:22px;}
.addbug h3{font-size:18px; margin-bottom:12px;}
.addbug .row{display:grid; grid-template-columns:200px 1fr; gap:12px; margin-bottom:10px;}
.addbug input, .addbug select, .addbug textarea{width:100%; padding:10px 12px; border:1.5px solid var(--line); border-radius:9px; font:inherit; background:#fff;}
.addbug textarea{min-height:64px; resize:vertical;}
.addbug .submit{background:var(--rust); color:#fff; border:none; border-radius:10px; padding:11px 20px; font-weight:800; cursor:pointer;}
.addbug .note{font-size:12px; color:var(--ink-soft); margin-top:6px;}

table.bugs{width:100%; border-collapse:collapse; background:var(--card); border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow);}
table.bugs th{background:var(--teal); color:#fff; text-align:left; font-size:12px; letter-spacing:.05em; text-transform:uppercase; padding:11px 12px;}
table.bugs td{padding:11px 12px; border-top:1px solid var(--line); font-size:14px; vertical-align:top;}
table.bugs tr:hover td{background:#fffdf7;}
.msg-cell{max-width:380px;}
.url-cell{max-width:200px; font-size:12px; color:var(--teal-d); word-break:break-all;}
.pill{display:inline-block; font-size:11px; font-weight:800; padding:3px 9px; border-radius:999px; text-transform:uppercase; letter-spacing:.04em;}
.pill.new{background:#fde2cf; color:#9a4a12;}
.pill.triaged{background:#d8ecf3; color:#0a6076;}
.pill.resolved{background:#d6f0df; color:#1f7a45;}
.pill.wontfix{background:#e4ddd2; color:#6b5b46;}
.act{display:flex; gap:6px; flex-wrap:wrap;}
.act button{font:inherit; font-size:12px; font-weight:700; padding:5px 9px; border-radius:7px; border:1.5px solid var(--line); background:#fff; cursor:pointer;}
.act button.fix{background:var(--teal); color:#fff; border:none;}
.act button.fix:hover{filter:brightness(1.08);}
.empty{text-align:center; color:var(--ink-soft); padding:40px;}
.prodtag{font-weight:800; color:var(--ink);}
