/* ============================================================
   nemeclaw.com — shared stylesheet (redesign 2026-06)
   Light, calm, conservative-modern. One accent: muted gold.
   Flashiness target: 3/10. No animation beyond subtle hover.
   ============================================================ */

:root{
  --paper:#faf7f2;          /* warm off-white page background */
  --card:#ffffff;
  --ink:#1c2733;            /* near-navy charcoal body text */
  --ink-soft:#46566b;
  --ink-muted:#6e7b8a;
  --navy:#1d3553;           /* deep navy — headings, buttons, footer */
  --navy-deep:#152840;
  --gold:#b08d3e;           /* accent */
  --gold-deep:#8a6d2f;      /* text-safe gold */
  --gold-pale:#f4ecd9;      /* gold tint backgrounds */
  --line:#e7e0d2;           /* warm hairline borders */
  --line-soft:#efe9dd;
  --ok:#2e7d52;             /* checkmarks / success only */
  --warn:#a04545;           /* errors only */
  --radius:12px;
  --radius-sm:8px;
  --shadow:0 1px 3px rgba(29,53,83,.08),0 8px 24px rgba(29,53,83,.06);
  --shadow-lift:0 2px 6px rgba(29,53,83,.10),0 14px 34px rgba(29,53,83,.10);
  --font-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-head:'Source Serif 4',Georgia,'Times New Roman',serif;
  --safe-bottom:env(safe-area-inset-bottom,0px);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--paper);color:var(--ink);
  line-height:1.65;font-size:16.5px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--gold-deep);text-decoration:none}
a:hover{text-decoration:underline}

h1,h2,h3,.serif{font-family:var(--font-head);color:var(--navy);line-height:1.2;letter-spacing:-.01em}
h1{font-size:clamp(34px,5vw,52px);font-weight:700}
h2{font-size:clamp(26px,3.4vw,36px);font-weight:700}
h3{font-size:21px;font-weight:600}
.kicker{font-family:var(--font-body);font-size:13px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--gold-deep);margin-bottom:12px}
.lede{font-size:clamp(17px,2vw,20px);color:var(--ink-soft);max-width:640px}

/* ---------- layout ---------- */
.container{max-width:1080px;margin:0 auto;padding:0 22px}
.section{padding:72px 0}
.section-tight{padding:48px 0}
.section-alt{background:#f3eee4}
.section-navy{background:var(--navy);color:#e9eef5}
.section-navy h2,.section-navy h3{color:#fff}
.section-navy p{color:#c6d2e0}
.center{text-align:center}
.section-head{max-width:680px;margin:0 auto 44px;text-align:center}
.section-head p{color:var(--ink-soft);margin-top:12px}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(250,247,242,.94);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.header-inner{max-width:1080px;margin:0 auto;padding:0 22px;height:66px;
  display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:11px;color:var(--navy);font-family:var(--font-head)}
.brand:hover{text-decoration:none}
.brand-mark{width:38px;height:38px;border-radius:8px;background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:19px;flex:0 0 auto}
.brand-name{font-weight:700;font-size:19px;line-height:1.15;white-space:nowrap}
.brand-name small{display:block;font-family:var(--font-body);font-weight:600;font-size:10.5px;
  letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted)}
.main-nav{display:flex;align-items:center;gap:2px;list-style:none;flex-wrap:nowrap}
.main-nav a{color:var(--ink-soft);font-size:14.5px;font-weight:600;padding:9px 12px;border-radius:8px;white-space:nowrap}
.main-nav a:hover{color:var(--navy);background:rgba(29,53,83,.06);text-decoration:none}
.main-nav a.active{color:var(--navy)}
.header-cta{display:flex;align-items:center;gap:10px;flex-shrink:0}
.header-cta .btn{white-space:nowrap}
.header-phone{font-weight:700;font-size:14.5px;color:var(--navy);white-space:nowrap}
.header-phone:hover{color:var(--gold-deep);text-decoration:none}

/* mobile nav */
.nav-toggle{display:none;background:none;border:1px solid var(--line);border-radius:8px;
  width:42px;height:42px;cursor:pointer;color:var(--navy);font-size:20px;line-height:1}
.mobile-nav{display:none;border-top:1px solid var(--line);background:var(--paper);padding:10px 22px 18px}
.mobile-nav.open{display:block}
.mobile-nav a{display:block;padding:11px 6px;font-weight:600;color:var(--ink-soft);
  border-bottom:1px solid var(--line-soft);font-size:15.5px}
.mobile-nav a:hover{color:var(--navy);text-decoration:none}
.mobile-nav a:last-child{border-bottom:none}
@media(max-width:1080px){
  .main-nav{display:none}
  .nav-toggle{display:block}
  .header-phone{display:none}
}

/* ---------- buttons ---------- */
.btn{display:inline-block;border:none;border-radius:var(--radius-sm);cursor:pointer;
  font-family:var(--font-body);font-weight:700;font-size:16px;padding:14px 26px;
  text-align:center;transition:background .15s,transform .15s,box-shadow .15s;line-height:1.3}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy-deep);transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-gold{background:var(--gold-deep);color:#fff}
.btn-gold:hover{background:#765d26;transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid var(--navy)}
.btn-outline:hover{background:rgba(29,53,83,.06)}
.btn-lg{font-size:17.5px;padding:16px 32px}
.btn-sm{font-size:14px;padding:10px 18px}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}
.btn-note{font-size:13px;color:var(--ink-muted);margin-top:10px}

/* ---------- cards ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;box-shadow:var(--shadow)}
.card h3{margin-bottom:8px}
.card p{color:var(--ink-soft);font-size:15.5px}
.card-link{display:block;color:inherit;transition:transform .15s,box-shadow .15s}
.card-link:hover{text-decoration:none;transform:translateY(-3px);box-shadow:var(--shadow-lift)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:860px){.grid-3{grid-template-columns:1fr}.grid-2{grid-template-columns:1fr}}

/* ---------- checklist ---------- */
.checklist{list-style:none;display:grid;gap:12px}
.checklist li{display:flex;gap:12px;align-items:flex-start;color:var(--ink-soft);font-size:15.5px}
.checklist li::before{content:"✓";color:var(--ok);font-weight:800;flex:0 0 auto;margin-top:1px}
.checklist b,.checklist strong{color:var(--ink)}

/* ---------- credibility strip ---------- */
.cred-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
.cred-strip .num{font-family:var(--font-head);font-size:30px;font-weight:700;color:var(--navy);line-height:1.15}
.cred-strip .lbl{font-size:13.5px;color:var(--ink-muted);font-weight:600;margin-top:4px}
@media(max-width:760px){.cred-strip{grid-template-columns:1fr 1fr;gap:26px 14px}}

/* ---------- steps ---------- */
.step-row{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:step}
.step{position:relative;padding:26px 24px 24px;background:var(--card);
  border:1px solid var(--line);border-radius:var(--radius)}
.step::before{counter-increment:step;content:counter(step);
  display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;
  border-radius:50%;background:var(--gold-pale);color:var(--gold-deep);
  font-weight:800;font-size:16px;margin-bottom:14px}
.step h3{font-size:18.5px}
.step p{color:var(--ink-soft);font-size:15px;margin-top:6px}
@media(max-width:860px){.step-row{grid-template-columns:1fr}}

/* ---------- testimonials ---------- */
.review-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px}
.review-stars{color:var(--gold);font-size:15px;letter-spacing:2px}
.review-quote{font-size:15.5px;color:var(--ink-soft);font-style:italic;flex:1}
.review-name{font-weight:700;font-size:14px;color:var(--navy)}
.review-name span{font-weight:500;color:var(--ink-muted)}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line);padding:4px 0}
.faq summary{cursor:pointer;font-weight:700;font-size:16.5px;color:var(--navy);
  padding:16px 30px 16px 2px;list-style:none;position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:6px;top:14px;font-size:22px;
  color:var(--gold-deep);font-weight:400;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .faq-a{padding:0 2px 18px;color:var(--ink-soft);font-size:15.5px}
.faq .faq-a p+p{margin-top:10px}

/* ---------- forms ---------- */
.field{margin-bottom:18px}
.field label{display:block;font-size:13.5px;font-weight:700;color:var(--ink-soft);margin-bottom:7px}
.field label .req{color:var(--gold-deep)}
.field input,.field select,.field textarea{width:100%;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:13px 15px;color:var(--ink);font-size:15.5px;
  font-family:inherit;transition:border-color .15s,box-shadow .15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;
  border-color:var(--gold);box-shadow:0 0 0 3px rgba(176,141,62,.18)}
.field textarea{resize:vertical;min-height:96px}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236e7b8a' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}
.err{color:var(--warn);font-size:12.5px;margin-top:6px;display:none}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:var(--warn)}
.field.invalid .err,.err.visible{display:block}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.grid2{grid-template-columns:1fr}}

/* ---------- notes / callouts ---------- */
.notebox{font-size:14px;color:var(--ink-soft);background:var(--gold-pale);
  border-left:3px solid var(--gold);padding:13px 16px;border-radius:6px}
.honesty{font-family:var(--font-head);font-size:18px;color:var(--navy);font-style:italic}

/* ---------- footer ---------- */
.site-footer{background:var(--navy);color:#b9c6d6;margin-top:0}
.footer-inner{max-width:1080px;margin:0 auto;padding:54px 22px 40px;
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:38px}
.footer-brand .brand-name{color:#fff}
.footer-brand p{font-size:14px;margin-top:12px;line-height:1.7}
.site-footer h4{color:#fff;font-size:13px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;margin-bottom:14px}
.site-footer ul{list-style:none;display:grid;gap:9px}
.site-footer a{color:#b9c6d6;font-size:14.5px}
.site-footer a:hover{color:#fff;text-decoration:none}
.footer-legal{border-top:1px solid rgba(255,255,255,.12)}
.footer-legal .container{padding-top:20px;padding-bottom:calc(24px + var(--safe-bottom));
  font-size:12.5px;color:#8fa1b5;line-height:1.7}
@media(max-width:760px){.footer-inner{grid-template-columns:1fr;gap:30px}}

/* ---------- mobile sticky call bar ---------- */
.mobile-bar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:99;
  background:var(--navy);padding:10px 14px calc(10px + var(--safe-bottom));
  grid-template-columns:1fr 1fr;gap:10px;box-shadow:0 -4px 18px rgba(21,40,64,.25)}
.mobile-bar a{display:block;text-align:center;border-radius:8px;font-weight:700;
  font-size:15px;padding:12px 10px;color:#fff}
.mobile-bar .mb-call{background:rgba(255,255,255,.13)}
.mobile-bar .mb-start{background:var(--gold-deep)}
.mobile-bar a:hover{text-decoration:none}
@media(max-width:760px){
  .mobile-bar{display:grid}
  body{padding-bottom:74px}
}

/* ---------- misc ---------- */
.divider{border:none;border-top:1px solid var(--line);margin:0}
.small{font-size:13.5px;color:var(--ink-muted)}
.tag{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--gold-deep);background:var(--gold-pale);
  border-radius:20px;padding:5px 12px}
