/* ============================================================
   KIELTY LAW, LLC — Site stylesheet
   Palette: ink navy / brass gold / ivory (from firm logo)
   Type: Cinzel (display) · Spectral (body) · Archivo (utility)
   ============================================================ */
:root{
  --ink:#0C1322;
  --black:#000;
  --panel:#121D32;
  --panel-2:#0F1830;
  --line:#24314D;
  --gold:#C49A3C;
  --gold-bright:#E2B654;
  --ivory:#F3EFE6;
  --slate:#97A1B4;
  --max:1140px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}
body{
  background:var(--ink);
  color:var(--ivory);
  font-family:'Spectral',Georgia,serif;
  font-weight:300;
  font-size:17px;
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--gold-bright);text-decoration:none}
a:hover{color:var(--ivory)}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--gold-bright);outline-offset:3px}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}

/* ---------- type ---------- */
h1,h2,h3,.display{font-family:'Cinzel',serif;font-weight:600;letter-spacing:.04em;line-height:1.18;color:var(--ivory)}
h1{font-size:clamp(2rem,5vw,3.4rem)}
h2{font-size:clamp(1.5rem,3.4vw,2.2rem)}
h3{font-size:1.15rem;letter-spacing:.06em}
.eyebrow{font-family:'Archivo',sans-serif;font-size:.72rem;font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.lede{font-size:1.15rem;color:#D6D2C6;max-width:62ch;margin-left:auto;margin-right:auto}
p+p{margin-top:1em;text-indent:1.5em}

/* gold star divider — carries the firm's print motif */
.star-rule{display:flex;align-items:center;gap:14px;margin:26px 0;color:var(--gold)}
.star-rule::before,.star-rule::after{content:"";height:1px;flex:1;background:linear-gradient(90deg,transparent,var(--gold));opacity:.55}
.star-rule::after{background:linear-gradient(90deg,var(--gold),transparent)}
.star-rule span{font-size:.8rem;letter-spacing:.1em}

/* ---------- top bar ---------- */
.topbar{background:var(--gold);color:#1A1406;font-family:'Archivo',sans-serif;font-size:.8rem;font-weight:600;letter-spacing:.06em;text-align:center;padding:8px 14px}
.topbar a{color:#1A1406;text-decoration:underline}

/* ---------- header / nav ---------- */
header.site{position:sticky;top:0;z-index:60;background:rgba(12,19,34,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 24px;max-width:var(--max);margin:0 auto}
.brand{display:flex;align-items:center;gap:12px;color:var(--ivory)}
.brand img{height:66px;width:auto}
.brand .bname{font-family:'Cinzel',serif;font-size:1.05rem;letter-spacing:.08em;line-height:1.2;white-space:nowrap}
.brand .btag{display:block;font-family:'Archivo',sans-serif;font-size:.58rem;letter-spacing:.34em;color:var(--gold);text-transform:uppercase}
nav.main{display:flex;align-items:center;gap:4px;font-family:'Archivo',sans-serif;font-size:.86rem;letter-spacing:.04em}
nav.main>div{position:relative}
nav.main a.top,nav.main button.top{display:block;padding:10px 13px;color:var(--ivory);background:none;border:0;font:inherit;cursor:pointer;letter-spacing:.05em}
nav.main a.top:hover,nav.main button.top:hover{color:var(--gold-bright)}
.drop{display:none;position:absolute;top:100%;left:0;min-width:250px;max-height:70vh;overflow:auto;background:var(--panel);border:1px solid var(--line);border-top:2px solid var(--gold);padding:8px 0;box-shadow:0 18px 40px rgba(0,0,0,.5)}
nav.main>div:hover .drop,nav.main>div:focus-within .drop{display:block}
.drop a{display:block;padding:9px 18px;color:#D6D2C6;font-size:.84rem}
.drop a:hover{background:var(--panel-2);color:var(--gold-bright)}
.drop .grp{padding:10px 18px 4px;font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold)}
.nav-cta{font-family:'Archivo',sans-serif;font-weight:700;font-size:.85rem;letter-spacing:.05em;background:var(--gold);color:#1A1406;padding:11px 18px;border-radius:3px;white-space:nowrap}
.nav-cta:hover{background:var(--gold-bright);color:#1A1406}
.menu-btn{display:none;background:none;border:1px solid var(--line);color:var(--ivory);font-family:'Archivo',sans-serif;font-size:.8rem;letter-spacing:.14em;padding:10px 14px;cursor:pointer;border-radius:3px}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;padding-top:64px;padding-bottom:64px}
.hero-img{position:relative}
.hero-img img{border:1px solid var(--line);box-shadow:0 30px 60px rgba(0,0,0,.55)}
.hero-img::after{content:"";position:absolute;inset:14px -14px -14px 14px;border:1px solid var(--gold);opacity:.45;pointer-events:none}
.hero h1 em{font-style:normal;color:var(--gold-bright)}
.hero .lede{margin:20px 0 28px}
.cta-row{display:flex;flex-wrap:wrap;gap:14px}
.btn{font-family:'Archivo',sans-serif;font-weight:700;font-size:.9rem;letter-spacing:.06em;padding:15px 26px;border-radius:3px;display:inline-block;text-align:center}
.btn-gold{background:var(--gold);color:#1A1406}
.btn-gold:hover{background:var(--gold-bright);color:#1A1406}
.btn-ghost{border:1px solid var(--gold);color:var(--gold-bright)}
.btn-ghost:hover{border-color:var(--gold-bright);color:var(--ivory)}

/* ---------- trial-record band (signature) ---------- */
.record{background:#000;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.record .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding-top:44px;padding-bottom:44px;text-align:center}
.record .num{font-family:'Cinzel',serif;font-size:clamp(2.2rem,5vw,3.2rem);color:var(--gold-bright);line-height:1}
.record .lbl{font-family:'Archivo',sans-serif;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--slate);margin-top:10px}

/* ---------- sections ---------- */
section.pad{padding:72px 0}
section.pad.tight{padding:52px 0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{background:var(--panel);border:1px solid var(--line);border-top:2px solid transparent;padding:26px 24px;transition:border-color .2s,transform .2s}
.card:hover{border-top-color:var(--gold);transform:translateY(-3px)}
.card h3{margin-bottom:10px}
.card h3 a{color:var(--ivory)}
.card h3 a:hover{color:var(--gold-bright)}
.card p{font-size:.95rem;color:#C9C5BA}
.card .more{display:inline-block;margin-top:14px;font-family:'Archivo',sans-serif;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase}
.quoteband{background:var(--panel-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center}
.quoteband .wrap{padding-top:64px;padding-bottom:64px}
.quoteband blockquote{font-family:'Cinzel',serif;font-size:clamp(1.3rem,3vw,2rem);line-height:1.4;max-width:20ch;margin:0 auto;color:var(--ivory)}
.quoteband blockquote em{font-style:normal;color:var(--gold-bright)}

/* ---------- page hero (interior) ---------- */
.page-hero{border-bottom:1px solid var(--line);background:
  linear-gradient(180deg,rgba(12,19,34,.6),var(--ink) 90%),
  radial-gradient(900px 300px at 80% 0%,rgba(196,154,60,.14),transparent)}
.page-hero .wrap{padding-top:60px;padding-bottom:48px;text-align:center}
.grid-2 p,.grid-2 p+p{text-indent:1.5em}
.crumbs{font-family:'Archivo',sans-serif;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--slate);margin-bottom:18px;text-align:center}
.crumbs a{color:var(--slate)}.crumbs a:hover{color:var(--gold-bright)}

/* ---------- article layout ---------- */
.article{display:grid;grid-template-columns:1fr 320px;gap:52px;align-items:start}
.article .body h2{margin:38px 0 14px}
.article .body p{text-indent:1.5em}
.article .body ul{margin:14px 0 14px 22px}
.article .body li{margin-bottom:8px}
.statute{background:var(--panel);border-left:3px solid var(--gold);padding:18px 22px;margin:24px 0;font-size:.95rem}
.statute .tag{font-family:'Archivo',sans-serif;font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:6px}
aside.rail{position:sticky;top:96px;display:flex;flex-direction:column;gap:18px}
.railbox{background:var(--panel);border:1px solid var(--line);padding:24px;text-align:center}
.railbox h3{font-size:.95rem;margin-bottom:12px;color:var(--gold-bright)}
.railbox .phone{font-family:'Cinzel',serif;font-size:1.5rem;color:var(--ivory);display:block;margin:6px 0 4px;text-align:center}
.railbox small{color:var(--slate);font-family:'Archivo',sans-serif;font-size:.72rem;letter-spacing:.08em}
.railbox ul{list-style:none}
.railbox li{border-bottom:1px solid var(--line)}
.railbox li:last-child{border:0}
.railbox li a{display:block;padding:9px 2px;font-size:.88rem;color:#D6D2C6}
.railbox li a:hover{color:var(--gold-bright)}

/* ---------- forms ---------- */
form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
label{display:block;font-family:'Archivo',sans-serif;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--slate);margin:18px 0 7px}
input,select,textarea{width:100%;background:var(--ink);border:1px solid var(--line);color:var(--ivory);font-family:'Spectral',serif;font-size:1rem;padding:13px 14px;border-radius:3px}
input:focus,select:focus,textarea:focus{border-color:var(--gold)}
textarea{min-height:130px;resize:vertical}
form .btn{margin-top:26px;border:0;cursor:pointer;font-size:.95rem;width:100%}
.form-note{font-size:.85rem;color:var(--slate);margin-top:14px}

/* ---------- testimonials ---------- */
.tcard{background:var(--panel);border:1px solid var(--line);padding:28px;position:relative}
.tcard::before{content:"\201C";font-family:'Cinzel',serif;font-size:3rem;color:var(--gold);position:absolute;top:8px;left:18px;opacity:.5}
.tcard p{font-size:.98rem;padding-top:14px}
.tcard .who{margin-top:16px;font-family:'Archivo',sans-serif;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.stars{color:var(--gold-bright);letter-spacing:.2em;margin-bottom:6px}

/* ---------- footer ---------- */
footer.site{border-top:1px solid var(--gold);background:var(--panel-2);margin-top:80px}
.fgrid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:36px;padding:56px 0 40px}
.fgrid h4{font-family:'Archivo',sans-serif;font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.fgrid ul{list-style:none}
.fgrid li{margin-bottom:8px}
.fgrid a{color:#C9C5BA;font-size:.88rem}
.fgrid a:hover{color:var(--gold-bright)}
.fgrid .fl{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.fgrid .fl img{height:72px}
.legal{border-top:1px solid var(--line);padding:26px 0 74px;font-size:.78rem;color:var(--slate);line-height:1.7}
.legal p+p{margin-top:8px}

/* ---------- floating contact dock ---------- */
.dock{position:fixed;bottom:0;left:0;right:0;z-index:90;display:flex;border-top:1px solid var(--gold);background:rgba(12,19,34,.97);backdrop-filter:blur(8px)}
.dock a,.dock button{flex:1;padding:15px 8px;text-align:center;font-family:'Archivo',sans-serif;font-weight:700;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;background:none;border:0;cursor:pointer;color:var(--ivory)}
.dock a+a,.dock button{border-left:1px solid var(--line)}
.dock .d-call{background:var(--gold);color:#1A1406}
.dock .d-chat{color:var(--gold-bright)}

/* chat panel */
.chat-panel{display:none;position:fixed;bottom:64px;right:14px;left:14px;max-width:380px;margin-left:auto;z-index:95;background:var(--panel);border:1px solid var(--gold);box-shadow:0 24px 60px rgba(0,0,0,.6);border-radius:6px;overflow:hidden}
.chat-panel.open{display:block}
.chat-head{background:var(--gold);color:#1A1406;font-family:'Archivo',sans-serif;font-weight:700;font-size:.85rem;letter-spacing:.06em;padding:13px 16px;display:flex;justify-content:space-between;align-items:center}
.chat-head button{background:none;border:0;font-size:1.1rem;cursor:pointer;color:#1A1406;line-height:1}
.chat-body{padding:18px}
.chat-body .bubble{background:var(--ink);border:1px solid var(--line);border-radius:8px;padding:12px 14px;font-size:.9rem;margin-bottom:14px}
.chat-body label{margin-top:10px}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .hero .wrap,.grid-2,.article{grid-template-columns:1fr}
  .article{gap:34px}
  aside.rail{position:static}
  .grid-3{grid-template-columns:1fr 1fr}
  .record .wrap{grid-template-columns:1fr 1fr;gap:30px}
  .fgrid{grid-template-columns:1fr 1fr}
  nav.main{display:none;position:absolute;top:100%;left:0;right:0;background:var(--panel);border-bottom:1px solid var(--gold);flex-direction:column;align-items:stretch;padding:10px 0 16px}
  nav.main.open{display:flex}
  nav.main>div{width:100%}
  .drop{position:static;display:block;border:0;box-shadow:none;background:transparent;padding-left:14px;max-height:none}
  nav.main button.top::after{content:" ▾"}
  .menu-btn{display:block}
  .nav-cta{display:none}
  .hero-img{order:-1;max-width:420px;margin:0 auto}
}
@media (max-width:560px){
  .grid-3{grid-template-columns:1fr}
  form .row{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}
  body{font-size:16px}
}
