/* ==========================================================================
   Cordan Electric - "Desert Modern" shared design system (all pages)
   Terracotta + slate on cool limestone. Archivo Expanded / Instrument Sans.
   Light theme locked. One accent (--clay). Zero em-dashes anywhere.
   ========================================================================== */
*{box-sizing:border-box;margin:0}
:root{
  --paper:#F3F2EF; --surface:#FFFFFF; --sand:#EBE7E0;
  --ink:#1C1B19; --body:#3C3B39; --muted:#5E5D5B; --line:#E2E0DB;
  --clay:#A8492A; --clay-ink:#8F3D20; --clay-hover:#8A3C1F; --amber:#E8A34B;
  --maxw:1200px; --r:4px; --ease:cubic-bezier(.16,1,.3,1);
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:"Instrument Sans",system-ui,sans-serif;background:var(--paper);color:var(--body);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:"Archivo",sans-serif;color:var(--ink);line-height:1.04;letter-spacing:-.03em;font-weight:800;text-wrap:balance}
.disp{font-family:"Archivo Expanded","Archivo",sans-serif}
h1{font-size:clamp(2.4rem,1.4rem+3.6vw,4.4rem)}
h2{font-size:clamp(2rem,1.4rem+2.4vw,3.1rem)}
h3{font-size:1.3rem;letter-spacing:-.02em}
p{text-wrap:pretty}
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:1.6rem}
.label{font-family:"Archivo",sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay-ink)}
.muted{color:var(--muted)}
.bleed{width:100vw;margin-inline:calc(50% - 50vw)}
.center{text-align:center;margin-inline:auto}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:"Archivo",sans-serif;font-weight:700;font-size:1rem;padding:.95rem 1.7rem;border-radius:var(--r);cursor:pointer;border:1.5px solid transparent;transition:transform .18s var(--ease),background .18s,border-color .18s,color .18s;min-height:52px}
.btn-primary{background:var(--clay);color:#fff}
.btn-primary:hover{background:var(--clay-hover);transform:translateY(-2px)}
.btn-line{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-line:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--clay-ink);border-color:#fff}
.btn-white:hover{background:var(--sand);transform:translateY(-2px)}
.btn-onink{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-onink:hover{background:#fff;color:var(--ink);transform:translatey(-2px)}
:focus-visible{outline:3px solid var(--clay);outline-offset:3px}

/* header */
header{position:sticky;top:0;z-index:100;background:rgba(243,242,239,.88);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:70px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:"Archivo Expanded","Archivo",sans-serif;font-weight:800;letter-spacing:-.01em;font-size:1.06rem;color:var(--ink)}
.brand .bolt{width:30px;height:30px;border-radius:6px;background:var(--ink);display:grid;place-items:center;flex:none}
.brand .bolt svg{color:var(--clay)}
.nav-links{display:flex;align-items:center;gap:.25rem}
.nav-links a{font-weight:500;font-size:.95rem;color:var(--body);padding:.5rem .8rem;border-radius:var(--r)}
.nav-links a:hover{color:var(--ink);background:var(--sand)}
.nav-links a[aria-current=page]{color:var(--clay-ink)}
.nav-cta{display:flex;align-items:center;gap:.7rem}
.nav-tel{font-family:"Archivo",sans-serif;font-weight:700;color:var(--ink);font-size:.95rem;white-space:nowrap}
.nav .btn{min-height:44px;padding:.6rem 1.15rem;font-size:.92rem}
.navtoggle{display:none;background:none;border:1px solid var(--line);border-radius:var(--r);padding:.5rem .6rem;cursor:pointer;color:var(--ink)}

/* home hero */
.hero{padding-block:clamp(2.5rem,4vw,4rem) clamp(2.5rem,5vw,4.5rem)}
.hero-grid{display:grid;gap:clamp(1.8rem,4vw,3.2rem);align-items:center}
@media(min-width:900px){.hero-grid{grid-template-columns:1.05fr 1fr}}
.hero h1{margin:1rem 0 0}
.hero h1 .clay{color:var(--clay)}
.hero .sub{font-size:1.2rem;color:var(--body);max-width:44ch;margin-top:1.3rem}
.hero .cta-row{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.9rem}
.hero-photo{position:relative;border-radius:6px;overflow:hidden;border:1px solid var(--line);box-shadow:0 40px 80px -34px rgba(28,27,25,.5);aspect-ratio:4/3.2}
.hero-photo img{width:100%;height:100%;object-fit:cover}

/* page hero (subpages) */
.phero{padding-block:clamp(2.6rem,5vw,4rem) clamp(1.6rem,3vw,2.4rem)}
.phero h1{margin-top:1rem;max-width:18ch}
.phero .sub{font-size:1.2rem;color:var(--body);max-width:56ch;margin-top:1.2rem}
.phero .cta-row{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.7rem}

/* trust band */
.trust{background:var(--ink);color:#fff}
.trust .row{display:flex;flex-wrap:wrap;gap:.4rem 2.4rem;justify-content:space-between;align-items:center;padding-block:1.1rem}
.trust .it{display:flex;align-items:center;gap:.6rem;font-size:.94rem;color:rgba(255,255,255,.86)}
.trust .it b{font-family:"Archivo",sans-serif;color:#fff;font-weight:700}
.trust .it .st{color:var(--amber);letter-spacing:1px}

/* sections */
section{padding-block:clamp(3.5rem,7vw,6rem)}
.shead{max-width:60ch}
.shead h2{margin-top:.7rem}
.shead p{font-size:1.15rem;color:var(--muted);margin-top:1rem}
.shead.center{margin-inline:auto}

/* WORK - alternating full-bleed plates */
.plate{padding-block:clamp(2.5rem,5vw,4.5rem)}
.plate + .plate{border-top:1px solid var(--line)}
.plate-grid{display:grid;gap:clamp(1.4rem,3vw,2.6rem);align-items:center}
@media(min-width:880px){.plate-grid{grid-template-columns:1.35fr 1fr}
  .plate.flip .p-img{order:2}.plate.flip .p-txt{order:1}}
.p-img{border-radius:6px;overflow:hidden;border:1px solid var(--line);box-shadow:0 30px 60px -34px rgba(28,27,25,.42);aspect-ratio:16/10}
.p-img img{width:100%;height:100%;object-fit:cover}
.p-txt .kicker{font-family:"Archivo",sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--clay-ink)}
.p-txt h3{font-size:clamp(1.5rem,1.1rem+1.4vw,2.1rem);margin:.6rem 0 .7rem}
.p-txt p{color:var(--muted);max-width:46ch}
.p-txt .tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.1rem}
.p-txt .tags b{font-weight:500;font-size:.82rem;color:var(--body);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:.35rem .8rem}

/* credibility badges */
.badges{display:flex;flex-wrap:wrap;gap:1.1rem 1.3rem;align-items:center;justify-content:center}
.badges img{height:54px;width:auto;background:var(--ink);border-radius:10px;padding:.7rem 1rem}
.morelink{display:inline-flex;align-items:center;gap:.45rem;margin-top:1.6rem;font-family:"Archivo",sans-serif;font-weight:700;color:var(--clay-ink)}
.morelink svg{transition:transform .2s var(--ease)}
.morelink:hover svg{transform:translateX(3px)}

/* client roster */
.roster{background:var(--sand)}
.roster .lead{text-align:center;font-family:"Archivo",sans-serif;font-weight:600;color:var(--muted);font-size:.92rem;letter-spacing:.02em;margin-bottom:1.6rem}
.logos{display:flex;flex-wrap:wrap;gap:2.4rem 3rem;align-items:center;justify-content:center}
.logos img{height:38px;width:auto;opacity:.72;filter:grayscale(1)}

/* services bento (home teaser) */
.svc{display:grid;gap:1.1rem;grid-template-columns:1fr}
@media(min-width:760px){.svc{grid-template-columns:repeat(4,1fr)}
  .s1{grid-column:span 2;grid-row:span 2}.s6{grid-column:span 2}}
.card{background:var(--surface);border:1px solid var(--line);border-radius:8px;overflow:hidden;display:flex;flex-direction:column}
.card .ph{aspect-ratio:16/10;overflow:hidden;background:var(--sand)}
.card.s1 .ph{aspect-ratio:auto;flex:1;min-height:200px}
.card .ph img{width:100%;height:100%;object-fit:cover}
.card .cb{padding:1.15rem 1.25rem}
.card h3{font-size:1.12rem}
.card.s1 h3{font-size:1.5rem}
.card p{font-size:.92rem;color:var(--muted);margin-top:.35rem}
.card .li{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.8rem}
.card .li b{font-weight:500;font-size:.78rem;color:var(--body);background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:.28rem .7rem}

/* services detail (services page) */
.svc-detail{display:grid;gap:1.1rem;grid-template-columns:1fr}
@media(min-width:720px){.svc-detail{grid-template-columns:1fr 1fr}}
.sd{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:1.6rem 1.6rem 1.7rem;display:flex;flex-direction:column;gap:.6rem}
.sd .ic{width:46px;height:46px;border-radius:9px;background:var(--sand);display:grid;place-items:center;color:var(--clay-ink)}
.sd h3{font-size:1.25rem}
.sd p{color:var(--muted);font-size:.98rem}
.sd ul{list-style:none;padding:0;margin:.3rem 0 0;display:grid;gap:.4rem}
.sd li{display:flex;gap:.55rem;font-size:.94rem;color:var(--body)}
.sd li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--clay);flex:none;margin-top:.5rem}

/* gallery grid */
.gal{columns:3 260px;column-gap:1rem}
.gal figure{break-inside:avoid;margin:0 0 1rem;border-radius:8px;overflow:hidden;border:1px solid var(--line);background:var(--surface)}
.gal img{width:100%;height:auto;display:block}
.gal figcaption{padding:.7rem .9rem;font-size:.86rem;color:var(--muted)}
.gal figcaption b{font-family:"Archivo",sans-serif;color:var(--ink);font-weight:700;display:block;font-size:.92rem}

/* about story */
.about{background:var(--ink);color:rgba(255,255,255,.86)}
.about h2,.about h3{color:#fff}
.about-grid{display:grid;gap:clamp(1.8rem,4vw,3rem);align-items:center}
@media(min-width:860px){.about-grid{grid-template-columns:1fr 1.1fr}}
.about .label{color:var(--amber)}
.about p{margin-top:1rem;max-width:52ch;color:rgba(255,255,255,.82)}
.about .vals{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.4rem}
.about .vals b{font-family:"Archivo",sans-serif;font-weight:600;font-size:.82rem;color:#fff;border:1px solid rgba(255,255,255,.24);border-radius:999px;padding:.4rem .9rem}
.owners{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.owner{border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.16)}
.owner img{width:100%;aspect-ratio:3/3.4;object-fit:cover}
.owner .cap{padding:.8rem 1rem;background:rgba(255,255,255,.05)}
.owner .cap b{font-family:"Archivo",sans-serif;color:#fff;display:block;font-size:1rem}
.owner .cap span{font-size:.82rem;color:rgba(255,255,255,.68)}

/* why-choose row (about) */
.why{display:grid;gap:1.1rem;grid-template-columns:1fr}
@media(min-width:720px){.why{grid-template-columns:repeat(3,1fr)}}
.why .w{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:1.5rem}
.why .w .n{font-family:"Archivo Expanded","Archivo",sans-serif;font-weight:800;color:var(--clay);font-size:1.6rem}
.why .w h3{margin:.5rem 0 .3rem;font-size:1.12rem}
.why .w p{color:var(--muted);font-size:.95rem}

/* reviews */
.revs{display:grid;gap:1.1rem;grid-template-columns:1fr}
@media(min-width:820px){.revs{grid-template-columns:repeat(3,1fr)}}
.rev{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:1.5rem 1.5rem 1.3rem;display:flex;flex-direction:column}
.rev .st{color:#D9862F;letter-spacing:2px;font-size:.95rem}
.rev q{quotes:none;display:block;margin-top:.8rem;color:var(--ink);font-size:1.02rem;line-height:1.55;flex:1}
.rev .who{display:flex;align-items:center;gap:.7rem;margin-top:1.3rem;padding-top:1.1rem;border-top:1px solid var(--line)}
.rev .who img{width:40px;height:40px;border-radius:50%;object-fit:cover;flex:none}
.rev .who b{font-family:"Archivo",sans-serif;font-size:.95rem;color:var(--ink);display:block}
.rev .who span{font-size:.8rem;color:var(--muted)}

/* contact */
.contact-grid{display:grid;gap:2rem;align-items:start}
@media(min-width:900px){.contact-grid{grid-template-columns:1.1fr .9fr;gap:3rem}}
.form{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:clamp(1.4rem,3vw,2.2rem)}
.field{margin-bottom:1rem;display:grid;gap:.4rem}
.field label{font-family:"Archivo",sans-serif;font-weight:600;font-size:.88rem;color:var(--ink)}
.field input,.field select,.field textarea{width:100%;font:inherit;font-size:1rem;color:var(--ink);background:var(--paper);border:1.5px solid var(--line);border-radius:var(--r);padding:.8rem .9rem;min-height:50px}
.field textarea{min-height:110px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--clay);box-shadow:0 0 0 3px rgba(168,73,42,.16)}
.row2{display:grid;gap:1rem}
@media(min-width:560px){.row2{grid-template-columns:1fr 1fr}}
.form .btn-primary{width:100%;margin-top:.3rem}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-ok{display:none;text-align:center;padding:2rem 1rem}
.form.sent .grid-in{display:none}.form.sent .form-ok{display:block}
.form-ok h3{color:var(--clay-ink);margin-bottom:.4rem}
.cside{display:grid;gap:1rem;align-content:start}
.ci{display:flex;gap:.9rem;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:1.1rem 1.2rem}
.ci .ico{width:40px;height:40px;flex:none;border-radius:8px;background:var(--sand);display:grid;place-items:center;color:var(--clay-ink)}
.ci h4{font-family:"Archivo",sans-serif;font-size:.98rem;color:var(--ink);margin-bottom:.15rem}
.ci p{font-size:.94rem;color:var(--muted)}
.ci a{color:var(--clay-ink);font-weight:600}
.emerg{background:var(--ink);color:#fff;border-color:var(--ink)}
.emerg .ico{background:rgba(255,255,255,.1);color:var(--amber)}
.emerg h4{color:#fff}.emerg p{color:rgba(255,255,255,.75)}.emerg a{color:var(--amber)}

/* closing CTA band */
.cta-band{background:var(--ink);color:#fff;text-align:center}
.cta-band h2{color:#fff;max-width:20ch;margin-inline:auto}
.cta-band p{color:rgba(255,255,255,.82);max-width:48ch;margin:1rem auto 1.9rem;font-size:1.14rem}
.cta-band .cta-row{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}

/* footer */
footer{background:var(--ink);color:rgba(255,255,255,.7);padding-block:3rem 2rem}
.foot{display:grid;gap:1.8rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.foot .brand{color:#fff;margin-bottom:.8rem}
.foot h4{font-family:"Archivo",sans-serif;color:#fff;font-size:.95rem;margin-bottom:.7rem}
.foot a,.foot p{display:block;color:rgba(255,255,255,.7);font-size:.93rem;padding:.15rem 0}
.foot a:hover{color:#fff}
.foot-bot{border-top:1px solid rgba(255,255,255,.14);margin-top:2.2rem;padding-top:1.3rem;font-size:.84rem;display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between}

/* reveal - content is ALWAYS visible; animation is pure decoration that can
   never leave anything hidden (safe if JS fails or the tab is backgrounded) */
.rv{opacity:1;transform:none}
@media(prefers-reduced-motion:no-preference){.js .rv{animation:rv-in .7s var(--ease) both}}
@keyframes rv-in{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@media(max-width:820px){
  .navtoggle{display:inline-flex}
  .nav-links{position:absolute;top:70px;left:0;right:0;flex-direction:column;align-items:stretch;background:var(--surface);border-bottom:1px solid var(--line);padding:.6rem 1.6rem 1.1rem;display:none}
  .nav-links.open{display:flex}.nav-links a{padding:.8rem .4rem}
  .nav-tel{display:none}
  .gal{columns:2 200px}
}
@media(max-width:520px){.gal{columns:1}}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important}.js .rv{opacity:1!important;transform:none!important;transition:none!important}.btn:hover{transform:none!important}}
