/* ============================================================
   STING SOLUTIONS — shared brand system (design tokens first)
   Renovation & Handyman · premium craftsman identity
   Built by BlueStone Webworks
   ============================================================ */
:root{
  /* primitives */
  --black:#0b0c0e; --char:#121419; --char2:#181b21; --steel:#21252d; --line:#2b303a; --line2:#3a4150;
  --cream:#f4f0e8; --muted:#9aa1ac; --muted2:#6b7280;
  --brass:#d6a23c; --brass-deep:#b9842a; --brass-soft:rgba(214,162,60,.12);
  --honey:#f1c977; --green:#5ad18a;
  /* semantic */
  --bg:var(--black); --surface:var(--char); --surface-2:var(--char2);
  --ink:var(--cream); --accent:var(--brass); --accent-2:var(--honey);
  /* type */
  --display:'Bebas Neue',Impact,sans-serif; --head:'Sora',sans-serif; --body:'Inter',sans-serif; --mono:'JetBrains Mono',monospace;
  --maxw:1180px; --radius:14px; --shadow:0 30px 70px -30px rgba(0,0,0,.8);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{background:var(--bg);color:var(--ink);font-family:var(--body);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--brass);color:#1a1205}
:focus-visible{outline:2px solid var(--brass);outline-offset:3px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.display{font-family:var(--display);letter-spacing:.5px;line-height:.92;text-transform:uppercase}
.eyebrow{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--brass)}
.accent{color:var(--brass)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--head);font-weight:600;font-size:15px;padding:14px 26px;border-radius:8px;border:1px solid transparent;transition:transform .14s ease,background .2s,border-color .2s,color .2s}
.btn:active{transform:translateY(1px)}
.btn-gold{background:linear-gradient(180deg,var(--honey),var(--brass));color:#1a1205;box-shadow:0 14px 30px -14px rgba(214,162,60,.8)}
.btn-gold:hover{filter:brightness(1.05);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line2)}
.btn-ghost:hover{border-color:var(--brass);color:var(--brass)}
.btn-lg{padding:17px 32px;font-size:16px}

/* header */
header.site{position:sticky;top:0;z-index:60;background:rgba(11,12,14,.8);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:.25s}
header.site.scrolled{background:rgba(9,10,12,.95);border-bottom-color:var(--line)}
.bar{display:flex;align-items:center;justify-content:space-between;height:74px;transition:height .25s}
header.site.scrolled .bar{height:62px}
.brand{display:flex;align-items:center;gap:12px}
.brand .mk{width:42px;height:42px;border-radius:11px;background:linear-gradient(140deg,var(--brass),var(--brass-deep));display:grid;place-items:center;color:#15100a;font-family:var(--display);font-size:26px;box-shadow:0 8px 20px -8px rgba(214,162,60,.7)}
.brand .bt{display:block;white-space:nowrap;font-family:var(--head);font-weight:700;text-transform:uppercase;letter-spacing:.5px;font-size:19px;line-height:1}
.brand .bt b{color:var(--brass)}
.brand .bs{display:block;font-family:var(--mono);font-size:9px;letter-spacing:2px;color:var(--muted2);text-transform:uppercase;margin-top:3px}
nav.main{display:flex;align-items:center;gap:26px;margin-left:auto;margin-right:26px}
nav.main a{font-family:var(--head);font-weight:500;font-size:14.5px;color:var(--muted);position:relative;padding:4px 0;transition:color .2s}
nav.main a:hover,nav.main a.active{color:var(--ink)}
nav.main a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--brass);transition:width .2s}
nav.main a:hover::after,nav.main a.active::after{width:100%}
.head-cta{display:flex;align-items:center;gap:14px}
.head-phone{font-family:var(--head);font-weight:600;font-size:15px;white-space:nowrap}
.head-phone small{display:block;font-family:var(--mono);font-size:9px;letter-spacing:2px;color:var(--muted2);text-transform:uppercase}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px}
.burger i{width:24px;height:2px;background:var(--ink);display:block;transition:.25s}
.mobile-nav{position:fixed;inset:0;z-index:55;background:var(--black);transform:translateX(100%);transition:transform .3s;display:flex;flex-direction:column;padding:96px 28px 40px;gap:4px}
.mobile-nav.open{transform:none}
.mobile-nav a{font-family:var(--display);font-size:30px;color:var(--ink);padding:14px 0;border-bottom:1px solid var(--line)}
.mobile-nav .btn{margin-top:22px;justify-content:center}
@media (max-width:860px){nav.main,.head-phone{display:none}.burger{display:flex}}

/* hazard accent line (subtle signature) */
.hz{height:3px;background:repeating-linear-gradient(135deg,var(--brass) 0 16px,transparent 16px 32px);opacity:.5}

/* hero */
.hero{position:relative;padding:96px 0 84px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:-2;background:radial-gradient(1100px 520px at 80% -10%,rgba(214,162,60,.13),transparent 60%),linear-gradient(180deg,#0d0e12,#0b0c0e)}
.hero::after{content:"";position:absolute;top:-20%;right:-10%;width:50%;height:140%;z-index:-1;opacity:.05;background:repeating-linear-gradient(135deg,var(--brass) 0 20px,transparent 20px 40px);-webkit-mask-image:linear-gradient(90deg,transparent,#000 70%);mask-image:linear-gradient(90deg,transparent,#000 70%)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.tagchip{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--line2);border-radius:40px;padding:7px 16px;font-family:var(--mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:24px}
.tagchip b{color:var(--brass)}
.hero h1{font-size:clamp(48px,7.6vw,96px);margin:0}
.hero h1 em{font-style:normal;color:var(--brass);display:block}
.hero .lede{font-size:clamp(17px,2vw,20px);color:var(--muted);max-width:31em;margin:22px 0 0}
.hero .lede b{color:var(--ink);font-weight:600}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.hero-trust{display:flex;gap:22px;flex-wrap:wrap;margin-top:30px;padding-top:22px;border-top:1px solid var(--line);font-size:13.5px;color:var(--muted)}
.hero-trust b{color:var(--brass)}
.hero-card{position:relative;background:linear-gradient(165deg,#181a20,#0f1014);border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}
.hero-card .ribbon{position:absolute;top:18px;right:-8px;background:linear-gradient(180deg,var(--honey),var(--brass));color:#1a1205;font-family:var(--head);font-weight:700;text-transform:uppercase;letter-spacing:1px;font-size:11px;padding:6px 14px;border-radius:3px}
.hero-card .bigmark{width:96px;height:96px;margin:8px auto 18px;border-radius:20px;background:linear-gradient(140deg,var(--brass),var(--brass-deep));display:grid;place-items:center;color:#15100a;font-family:var(--display);font-size:60px}
.hero-card .stamp{font-family:var(--mono);font-size:11px;letter-spacing:2px;color:var(--muted2);text-transform:uppercase;text-align:center;line-height:1.8}
.hero-card .stamp b{color:var(--ink)}
.hero-card .cap{margin-top:20px;border-top:1px dashed var(--line2);padding-top:18px;display:grid;grid-template-columns:1fr 1fr;gap:14px;text-align:center}
.hero-card .cap .n{font-family:var(--display);font-size:32px;color:var(--brass);line-height:1}
.hero-card .cap .l{font-size:12px;color:var(--muted);margin-top:4px}

/* sections */
.sec{padding:88px 0}
.sec-head{max-width:680px;margin-bottom:48px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{font-size:clamp(32px,4.8vw,54px);margin-top:14px}
.sec-head p{color:var(--muted);font-size:17px;margin-top:16px}
.band{background:linear-gradient(180deg,#101216,#0c0d10);border-block:1px solid var(--line)}

/* quote band */
.qband{padding:60px 0;display:grid;grid-template-columns:auto 1fr;gap:30px;align-items:center}
.qband .q{font-family:var(--display);font-size:120px;color:var(--brass);line-height:.6;opacity:.85}
.qband p{font-family:var(--head);font-weight:500;font-size:clamp(20px,2.7vw,30px);line-height:1.3}
.qband p b{color:var(--brass)}

/* service cards */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:28px 24px;overflow:hidden;transition:transform .18s,border-color .2s,background .2s}
.svc::before{content:"";position:absolute;left:0;top:0;height:100%;width:3px;background:var(--brass);transform:scaleY(0);transform-origin:top;transition:transform .22s}
.svc:hover{transform:translateY(-5px);border-color:var(--line2);background:var(--surface-2)}
.svc:hover::before{transform:scaleY(1)}
.svc .ic{width:46px;height:46px;border-radius:11px;background:var(--brass-soft);color:var(--brass);display:grid;place-items:center;margin-bottom:16px}
.svc .ic svg{width:24px;height:24px}
.svc h3{font-family:var(--head);font-weight:600;font-size:18px;margin-bottom:8px}
.svc p{color:var(--muted);font-size:14.5px}

/* process */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step{position:relative;padding:30px 24px;border:1px solid var(--line);border-radius:12px;background:var(--surface)}
.step .num{font-family:var(--display);font-size:50px;line-height:.8;-webkit-text-stroke:1px var(--brass-deep);color:transparent}
.step h4{font-family:var(--head);font-weight:600;font-size:17px;margin:14px 0 8px}
.step p{color:var(--muted);font-size:14px}

/* work gallery — premium placeholder slots */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.slot{position:relative;aspect-ratio:4/3;border-radius:12px;overflow:hidden;border:1px dashed var(--line2);background:linear-gradient(135deg,#15171c,#101216);display:grid;place-items:center}
.slot .in{position:absolute;left:0;right:0;bottom:0;z-index:3;display:flex;align-items:flex-end;gap:8px;padding:12px 15px;background:linear-gradient(to top,rgba(8,9,11,.88),rgba(8,9,11,.15) 60%,transparent);color:#f4f0e8;font-family:var(--mono);font-size:10.5px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;text-align:left}
.slot::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 35%,rgba(214,162,60,.07) 50%,transparent 65%);transform:translateX(-100%);animation:sh 3s infinite}
@keyframes sh{to{transform:translateX(100%)}}

/* reviews */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.rev{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:28px 24px;display:flex;flex-direction:column}
.rev .stars{color:var(--brass);letter-spacing:3px;margin-bottom:14px}
.rev p{font-size:15px;flex:1;color:var(--muted)}
.rev .by{margin-top:18px;padding-top:16px;border-top:1px solid var(--line);font-family:var(--head);font-size:14px}
.rev .by b{color:var(--brass)}
.rev .by span{display:block;font-family:var(--body);color:var(--muted2);font-size:12.5px;margin-top:2px}

/* FAQ */
details{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:18px 22px;margin-bottom:12px}
summary{font-family:var(--head);font-weight:600;font-size:16px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px;align-items:center}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";color:var(--brass);font-size:1.5rem;line-height:1}
details[open] summary::after{content:"\2013"}
details .a{color:var(--muted);margin-top:12px}

/* CTA + contact */
.cta-inner{background:linear-gradient(160deg,#1a1c22,#0e0f13);border:1px solid var(--line);border-radius:18px;overflow:hidden;display:grid;grid-template-columns:1fr 1fr}
.cta-left{padding:54px 46px;position:relative}
.cta-left::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(180deg,var(--honey),var(--brass))}
.cta-left h2{font-size:clamp(32px,4.6vw,52px);margin:14px 0 16px}
.cta-left p{color:var(--muted);max-width:26em;margin-bottom:24px}
.cta-direct{display:flex;flex-direction:column;gap:14px;margin-top:26px}
.cta-direct a,.cta-direct div{display:flex;align-items:center;gap:14px;font-family:var(--head);font-size:17px}
.cta-direct .ic{width:42px;height:42px;flex:0 0 auto;border-radius:9px;background:var(--brass-soft);color:var(--brass);display:grid;place-items:center}
.cta-direct small{display:block;font-family:var(--mono);font-size:10px;letter-spacing:2px;color:var(--muted2);text-transform:uppercase}
.cta-form{padding:46px;background:rgba(8,9,11,.5);border-left:1px solid var(--line)}
.cta-form h3{font-family:var(--head);font-weight:600;font-size:20px;margin-bottom:4px}
.cta-form .sub{color:var(--muted2);font-size:13px;margin-bottom:22px}
.fl{display:block;margin-bottom:15px}
.fl span{display:block;font-family:var(--head);font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:7px}
.fl input,.fl select,.fl textarea{width:100%;background:var(--black);border:1px solid var(--line2);color:var(--ink);border-radius:8px;padding:12px 14px;font-size:15px;font-family:inherit;transition:border-color .2s}
.fl input:focus,.fl select:focus,.fl textarea:focus{outline:none;border-color:var(--brass)}
.fl textarea{resize:vertical;min-height:90px}
.form-ok{display:none;background:rgba(76,175,126,.12);border:1px solid rgba(76,175,126,.4);color:#9be7b8;border-radius:8px;padding:13px 15px;font-size:14px;margin-bottom:14px}
.form-ok.show{display:block}

/* inner page hero */
.page-hero{padding:70px 0 40px;border-bottom:1px solid var(--line);background:radial-gradient(800px 300px at 80% -20%,rgba(214,162,60,.10),transparent 60%)}
.page-hero h1{font-size:clamp(40px,6vw,72px);margin-top:14px}
.page-hero p{color:var(--muted);font-size:18px;margin-top:14px;max-width:60ch}
.prose{max-width:760px}
.prose h2{font-family:var(--head);font-size:24px;margin:32px 0 10px}
.prose p,.prose li{color:var(--muted);margin-bottom:12px}
.prose ul{padding-left:22px}

/* footer */
footer.site{border-top:1px solid var(--line);background:#08090b;padding:56px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:36px}
.foot-brand p{color:var(--muted2);font-size:14px;margin-top:14px;max-width:32em}
.foot-col h5{font-family:var(--head);text-transform:uppercase;letter-spacing:1.5px;font-size:13px;color:var(--muted);margin-bottom:16px}
.foot-col a,.foot-col p{display:block;color:var(--muted);font-size:14.5px;margin-bottom:11px;transition:color .2s}
.foot-col a:hover{color:var(--brass)}
.foot-bottom{margin-top:40px;padding-top:22px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:var(--muted2);font-size:12px;font-family:var(--mono);letter-spacing:1px;text-transform:uppercase}

/* AI assistant widget (the bundled-AI differentiator) */
.ai-fab{position:fixed;right:22px;bottom:22px;z-index:80;display:flex;align-items:center;gap:10px;background:linear-gradient(180deg,var(--honey),var(--brass));color:#1a1205;font-family:var(--head);font-weight:600;font-size:14px;padding:13px 18px;border:0;border-radius:40px;box-shadow:0 16px 34px -12px rgba(214,162,60,.7);transition:transform .15s}
.ai-fab:hover{transform:translateY(-2px)}
.ai-fab .dot{width:8px;height:8px;border-radius:50%;background:#1a5e36;box-shadow:0 0 0 3px rgba(26,94,54,.25)}
.ai-panel{position:fixed;right:22px;bottom:22px;z-index:81;width:min(360px,calc(100vw - 44px));height:480px;max-height:calc(100vh - 44px);background:var(--char);border:1px solid var(--line2);border-radius:16px;box-shadow:var(--shadow);display:none;flex-direction:column;overflow:hidden}
.ai-panel.open{display:flex}
.ai-head{background:linear-gradient(160deg,#1a1c22,#101216);padding:16px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px}
.ai-head .av{width:38px;height:38px;border-radius:10px;background:linear-gradient(140deg,var(--brass),var(--brass-deep));display:grid;place-items:center;color:#15100a;font-family:var(--display);font-size:22px}
.ai-head b{font-family:var(--head);font-size:15px}
.ai-head small{display:block;color:var(--green);font-size:11px}
.ai-head .x{margin-left:auto;background:none;border:0;color:var(--muted);font-size:20px}
.ai-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px}
.msg{max-width:84%;padding:11px 14px;border-radius:13px;font-size:14px;line-height:1.5}
.msg.bot{background:var(--steel);color:var(--ink);align-self:flex-start;border-bottom-left-radius:4px}
.msg.me{background:linear-gradient(180deg,var(--honey),var(--brass));color:#1a1205;align-self:flex-end;border-bottom-right-radius:4px}
.ai-quick{display:flex;gap:8px;flex-wrap:wrap;padding:0 18px 10px}
.ai-quick button{background:var(--surface-2);border:1px solid var(--line2);color:var(--muted);font-size:12.5px;padding:7px 12px;border-radius:20px;transition:.2s}
.ai-quick button:hover{border-color:var(--brass);color:var(--ink)}
.ai-foot{padding:12px 14px;border-top:1px solid var(--line);display:flex;gap:8px}
.ai-foot input{flex:1;background:var(--black);border:1px solid var(--line2);color:var(--ink);border-radius:20px;padding:10px 14px;font-size:14px}
.ai-foot input:focus{outline:none;border-color:var(--brass)}
.ai-foot button{background:linear-gradient(180deg,var(--honey),var(--brass));border:0;color:#1a1205;width:40px;border-radius:50%;font-size:16px}
.ai-note{font-size:10.5px;color:var(--muted2);text-align:center;padding:0 0 8px}

/* reveal */
.rv{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.rv.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}}

/* responsive */
@media (max-width:1000px){
  .hero-grid{grid-template-columns:1fr;gap:36px}.hero-card{max-width:440px}
  .svc-grid,.rev-grid,.gallery{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .cta-inner{grid-template-columns:1fr}.cta-form{border-left:0;border-top:1px solid var(--line)}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:620px){
  .sec{padding:62px 0}
  .svc-grid,.rev-grid,.gallery,.steps{grid-template-columns:1fr}
  .qband{grid-template-columns:1fr;gap:12px}.qband .q{font-size:80px}
  .cta-left,.cta-form{padding:34px 24px}
  .foot-grid{grid-template-columns:1fr}
}

/* --- form hardening + conversion components (BlueStone standard) --- */
.hp{position:absolute!important;left:-9999px;top:-9999px;height:0;width:0;opacity:0;overflow:hidden}
.consent{display:flex;align-items:flex-start;gap:9px;margin:6px 0 2px;font-size:13px;color:var(--muted);cursor:pointer;line-height:1.45}
.consent input{margin-top:3px;accent-color:var(--brass);flex:none}
.fl input[type=file]{font-size:13px;color:var(--muted);padding:10px;border:1px dashed var(--line2);border-radius:8px;background:var(--char)}
.form-ok.err{border-color:#a8443f;color:#f0c4c0;background:rgba(168,68,63,.1)}
.mobile-bar{display:none}
@media (max-width:860px){
  .mobile-bar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:50;background:rgba(11,12,14,.97);backdrop-filter:blur(10px);border-top:1px solid var(--line);padding:8px 8px calc(8px + env(safe-area-inset-bottom));gap:8px}
  .mobile-bar a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-height:52px;padding:7px 4px;border-radius:11px;font-family:var(--head);font-weight:600;font-size:12px;color:var(--ink);background:var(--char2);border:1px solid var(--line)}
  .mobile-bar a svg{width:19px;height:19px}
  .mobile-bar a.mb-quote{background:linear-gradient(180deg,var(--honey),var(--brass));color:#1a1205;border-color:transparent}
  body{padding-bottom:78px}
  .ai-fab{bottom:90px!important}
}

/* --- brand mark: hornet logo (BlueStone) --- */
.brand .mk{background:#0b0c0e url('photos/logo-mark.png') center/115% no-repeat!important;color:transparent!important;font-size:0!important;box-shadow:0 6px 18px -9px rgba(214,162,60,.55)}
.foot-brand .mk{background:#0b0c0e url('photos/logo-mark.png') center/115% no-repeat!important;color:transparent!important;font-size:0!important}
.hero-card .bigmark{background:#0b0c0e url('photos/logo-mark.png') center/112% no-repeat!important;color:transparent!important;font-size:0!important}
