/* ============================================================
   ACTION DAN RENOS — Kelowna general contractor
   Warm-rugged craftsman system
   ============================================================ */

:root{
  --ink:#15130f;          /* warm near-black (railings, dark sections) */
  --ink-2:#241f18;
  --ink-3:#36302705;
  --paper:#f4efe7;        /* warm off-white */
  --paper-2:#eae3d6;      /* sand */
  --paper-3:#e2d9c8;
  --cedar:#b5732e;        /* accent — cedar amber */
  --cedar-deep:#8a531c;
  --cedar-soft:#caa169;
  --deck:#9aa0a0;         /* composite deck grey */
  --text:#211d16;
  --text-soft:#564d3e;
  --text-mute:#6b6150;
  --line:#0000001a;
  --line-strong:#00000033;
  --paper-line:#ffffff24;
  --maxw:1240px;
  --r:4px;
  --shadow:0 1px 2px rgba(0,0,0,.06), 0 10px 30px -12px rgba(20,15,8,.18);
  --shadow-lg:0 30px 70px -30px rgba(20,15,8,.45);
  --accent:var(--cedar);
  --accent-deep:var(--cedar-deep);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"Archivo",system-ui,sans-serif;
  color:var(--text);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  font-size:18px;
  line-height:1.6;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

/* ---- display type ---- */
.anton{font-family:"Anton",sans-serif;font-weight:400;text-transform:uppercase;letter-spacing:.01em;line-height:.92;}
.eyebrow{
  font-family:"Archivo",sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;
  color:var(--accent-deep);
}
.eyebrow.on-dark{color:var(--cedar-soft);}

/* ============================================================ HEADER */
.site-header{
  position:sticky;top:0;z-index:50;
  background:linear-gradient(180deg, rgba(21,19,15,.6), rgba(21,19,15,0));
  transition:background .3s ease, box-shadow .3s ease;
}
.site-header.solid{
  background:var(--ink);
  box-shadow:0 1px 0 var(--paper-line), 0 18px 40px -28px rgba(0,0,0,.8);
}
.nav{display:flex;align-items:center;gap:30px;height:74px;}
.brand{display:flex;align-items:center;gap:12px;color:#fff;}
.brand-logo{
  height:52px;width:auto;flex:none;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,.4));
}
.footer .brand-logo{height:56px;}
.brand-name{display:flex;flex-direction:column;line-height:1;}
.brand-name b{font-family:"Anton",sans-serif;font-weight:400;font-size:18px;letter-spacing:.02em;text-transform:uppercase;}
.brand-name span{font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--cedar-soft);font-weight:700;margin-top:3px;}
.nav-links{display:flex;gap:26px;margin-left:18px;}
.nav-links a{color:#efe7d8;font-weight:500;font-size:.95rem;letter-spacing:.01em;opacity:.9;text-shadow:0 1px 8px rgba(0,0,0,.35);transition:opacity .2s;}
.nav-links a:hover{opacity:1;}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:18px;}
.nav-phone{display:flex;align-items:center;gap:8px;color:#fff;font-weight:700;font-size:.95rem;}
.nav-phone svg{width:16px;height:16px;color:var(--cedar-soft);}

.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-weight:700;font-size:.95rem;letter-spacing:.01em;
  padding:13px 22px;border-radius:var(--r);border:0;
  transition:transform .15s ease, background .2s ease, box-shadow .2s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 6px 18px -6px rgba(138,83,28,.6);}
.btn-primary:hover{background:var(--accent-deep);}
.btn-ghost{background:transparent;color:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.5);}
.btn-ghost:hover{background:rgba(255,255,255,.1);}
.btn-dark{background:var(--ink);color:#fff;}
.btn-dark:hover{background:var(--ink-2);}
.btn-lg{padding:17px 30px;font-size:1.02rem;}
.btn svg{width:17px;height:17px;}

.hamburger{display:none;background:none;border:0;color:#fff;padding:6px;}
.hamburger svg{width:28px;height:28px;}

/* ============================================================ HERO */
.hero{position:relative;display:flex;flex-direction:column;justify-content:flex-end;min-height:92vh;color:#fff;overflow:hidden;margin-top:-74px;padding-top:74px;}
.hero-bg{position:absolute;inset:0;z-index:0;}
.hero-bg img{width:100%;height:100%;object-fit:cover;}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg, rgba(11,9,6,.88) 0%, rgba(11,9,6,.62) 34%, rgba(11,9,6,.2) 64%, rgba(11,9,6,0) 88%),
    linear-gradient(180deg, rgba(11,9,6,.34) 0%, rgba(11,9,6,.14) 30%, rgba(11,9,6,.5) 70%, rgba(11,9,6,.95) 100%),
    linear-gradient(rgba(11,9,6,.26), rgba(11,9,6,.26));
}
.hero-inner{position:relative;z-index:1;width:100%;padding-bottom:56px;padding-top:40px;}
.hero .eyebrow{display:block;margin-bottom:6px;}
.hero h1{
  font-size:clamp(2.2rem,3.7vw,3.5rem);
  max-width:20ch;margin:.28em 0 0;
  text-shadow:0 2px 30px rgba(0,0,0,.55);
}
.hero h1 em{font-style:normal;color:var(--cedar-soft);}
.hero-sub{max-width:52ch;font-size:1.12rem;color:#f3ece0;margin:18px 0 0;text-shadow:0 1px 12px rgba(0,0,0,.65);}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px;}

/* trust strip */
.trust{
  position:relative;z-index:1;background:var(--ink);
  border-top:1px solid var(--paper-line);
}
.trust-row{display:flex;flex-wrap:wrap;gap:8px 38px;padding:20px 0;}
.trust-item{display:flex;align-items:center;gap:11px;color:#efe7d8;font-weight:600;font-size:.95rem;}
.trust-item svg{width:20px;height:20px;color:var(--cedar-soft);flex:none;}

/* ============================================================ SECTION SHELL */
section{position:relative;}
.band{padding:96px 0;}
.band-paper{background:var(--paper);}
.band-sand{background:var(--paper-2);}
.band-ink{background:var(--ink);color:#f3ece0;}
.sec-head{max-width:760px;margin-bottom:52px;}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.sec-head h2{font-size:clamp(2.1rem,4.4vw,3.5rem);margin:.28em 0 0;color:var(--ink);}
.band-ink .sec-head h2{color:#fff;}
.sec-head p{font-size:1.12rem;color:var(--text-soft);margin:.7em 0 0;max-width:60ch;}
.band-ink .sec-head p{color:#d8cdba;}

/* ============================================================ SERVICES */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.svc{
  position:relative;border-radius:var(--r);overflow:hidden;background:#fff;
  box-shadow:var(--shadow);border:1px solid var(--line);
  transition:transform .25s ease, box-shadow .25s ease;
  display:flex;flex-direction:column;min-height:300px;
}
.svc:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);}
.svc-img{aspect-ratio:16/10;overflow:hidden;background:var(--paper-3);}
.svc-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1);}
.svc:hover .svc-img img{transform:scale(1.06);}
.svc-body{padding:22px 22px 26px;flex:1;display:flex;flex-direction:column;}
.svc-num{font-family:"Anton",sans-serif;font-size:13px;color:var(--cedar);letter-spacing:.1em;}
.svc h3{font-size:1.28rem;margin:6px 0 8px;color:var(--ink);font-weight:700;letter-spacing:-.01em;}
.svc p{margin:0;color:var(--text-soft);font-size:.98rem;line-height:1.5;}

/* ============================================================ PROCESS STRIP */
.process{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-lg);}
.pstep{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--ink);}
.pstep img{width:100%;height:100%;object-fit:cover;opacity:.96;}
.pstep::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(21,19,15,0) 40%,rgba(21,19,15,.85));}
.pstep-cap{position:absolute;left:0;bottom:0;z-index:2;padding:22px;color:#fff;}
.pstep-cap .n{font-family:"Anton",sans-serif;font-size:34px;color:var(--cedar-soft);line-height:1;}
.pstep-cap h4{margin:6px 0 2px;font-size:1.2rem;font-weight:700;}
.pstep-cap p{margin:0;font-size:.9rem;color:#d8cdba;}
.pstep + .pstep{border-left:2px solid var(--ink);}

/* ============================================================ GALLERY */
.filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:30px;}
.chip{
  background:#fff;border:1px solid var(--line-strong);color:var(--text);
  padding:10px 18px;border-radius:100px;font-weight:600;font-size:.92rem;
  transition:all .18s ease;
}
.chip:hover{border-color:var(--cedar);color:var(--cedar-deep);}
.chip.active{background:var(--ink);color:#fff;border-color:var(--ink);}
.band-ink .chip{background:#ffffff10;color:#efe7d8;border-color:#ffffff2e;}
.band-ink .chip.active{background:var(--cedar);border-color:var(--cedar);color:#fff;}

.gallery{columns:3;column-gap:16px;}
.gitem{
  position:relative;break-inside:avoid;margin-bottom:16px;border-radius:var(--r);
  overflow:hidden;cursor:pointer;background:var(--ink);box-shadow:var(--shadow);
  transition:opacity .35s ease, transform .35s ease;
}
.gitem img{width:100%;transition:transform .6s cubic-bezier(.2,.7,.2,1);}
.gitem:hover img{transform:scale(1.05);}
.gitem .tag{
  position:absolute;left:12px;top:12px;z-index:2;
  background:rgba(21,19,15,.78);color:#fff;backdrop-filter:blur(4px);
  font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:6px 11px;border-radius:100px;opacity:0;transform:translateY(-4px);transition:.25s;
}
.gitem:hover .tag{opacity:1;transform:none;}
.gitem::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.15),rgba(0,0,0,0) 30%);opacity:0;transition:.25s;}
.gitem:hover::after{opacity:1;}
.gitem.hide{display:none;}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(12,10,7,.94);display:none;align-items:center;justify-content:center;padding:30px;}
.lightbox.open{display:flex;}
.lightbox img{max-width:92vw;max-height:84vh;border-radius:var(--r);box-shadow:0 40px 120px -30px #000;}
.lb-cap{position:absolute;bottom:26px;left:0;right:0;text-align:center;color:#e9dfce;font-size:.95rem;letter-spacing:.02em;}
.lb-close,.lb-nav{position:absolute;background:#ffffff14;border:1px solid #ffffff2e;color:#fff;border-radius:100px;display:grid;place-items:center;transition:background .2s;}
.lb-close{top:22px;right:24px;width:46px;height:46px;}
.lb-nav{top:50%;transform:translateY(-50%);width:54px;height:54px;}
.lb-nav:hover,.lb-close:hover{background:#ffffff2e;}
.lb-prev{left:24px;}.lb-next{right:24px;}
.lb-close svg,.lb-nav svg{width:24px;height:24px;}

/* ============================================================ ABOUT */
.about-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center;}
.about-photo{position:relative;}
.about-photo img{border-radius:var(--r);box-shadow:var(--shadow-lg);width:100%;aspect-ratio:4/5;object-fit:cover;}
.about-badge{
  position:absolute;right:-18px;bottom:-22px;background:var(--cedar);color:#fff;
  padding:18px 22px;border-radius:var(--r);box-shadow:var(--shadow-lg);max-width:200px;
}
.about-badge .anton{font-size:30px;line-height:.9;}
.about-badge span{font-size:.82rem;font-weight:600;display:block;margin-top:6px;color:#fff;opacity:.92;}
.about-copy h2{font-size:clamp(2rem,4vw,3.1rem);color:var(--ink);margin:.2em 0 0;}
.about-copy p{color:var(--text-soft);font-size:1.1rem;margin:1em 0 0;}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px;}
.value{display:flex;flex-direction:column;gap:8px;}
.value svg{width:26px;height:26px;color:var(--cedar);}
.value b{font-size:1rem;color:var(--ink);}
.value small{color:var(--text-mute);font-size:.86rem;line-height:1.4;}

/* ============================================================ AREAS */
.areas-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.area-chips{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px;}
.area-chips .a{
  display:flex;align-items:center;gap:9px;background:#ffffff10;border:1px solid #ffffff24;
  color:#fff;padding:12px 18px;border-radius:var(--r);font-weight:600;
}
.area-chips .a svg{width:16px;height:16px;color:var(--cedar-soft);}
.area-map{position:relative;aspect-ratio:5/4;border-radius:var(--r);overflow:hidden;border:1px solid var(--paper-line);background:#1b1812;}
.area-map img{width:100%;height:100%;object-fit:cover;opacity:.5;}
.area-map .stamp{position:absolute;inset:0;display:grid;place-items:center;text-align:center;}
.area-map .stamp .anton{font-size:clamp(2rem,5vw,3.4rem);color:#fff;}
.area-map .stamp small{display:block;color:var(--cedar-soft);font-weight:700;letter-spacing:.2em;text-transform:uppercase;font-size:.75rem;margin-top:8px;}

/* ============================================================ QUOTE / CONTACT */
.quote-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:60px;align-items:start;}
.quote-aside h2{font-size:clamp(2.1rem,4.4vw,3.4rem);color:#fff;margin:.2em 0 0;}
.quote-aside p{color:#d8cdba;font-size:1.12rem;margin:1em 0 0;max-width:42ch;}
.contact-list{margin-top:34px;display:flex;flex-direction:column;gap:6px;}
.contact-row{display:flex;align-items:center;gap:16px;padding:16px 0;border-top:1px solid var(--paper-line);}
.contact-row:last-child{border-bottom:1px solid var(--paper-line);}
.contact-ic{width:44px;height:44px;flex:none;border-radius:50%;display:grid;place-items:center;background:#ffffff12;color:var(--cedar-soft);}
.contact-ic svg{width:20px;height:20px;}
.contact-row b{display:block;color:#fff;font-size:1.05rem;}
.contact-row small{color:#b6ab98;font-size:.85rem;}

.form-card{background:var(--paper);border-radius:var(--r);padding:34px;box-shadow:var(--shadow-lg);}
.form-card h3{margin:0 0 4px;color:var(--ink);font-size:1.4rem;}
.form-card .sub{color:var(--text-soft);font-size:.95rem;margin:0 0 22px;}
.field{margin-bottom:16px;}
.field label{display:block;font-weight:700;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;color:var(--text-soft);margin-bottom:7px;}
.field input,.field select,.field textarea{
  width:100%;padding:13px 15px;border-radius:var(--r);border:1.5px solid var(--line-strong);
  background:#fff;font-family:inherit;font-size:1rem;color:var(--text);transition:border .18s, box-shadow .18s;
}
.field textarea{resize:vertical;min-height:108px;}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--cedar);box-shadow:0 0 0 3px rgba(181,115,46,.16);}
.field.err input,.field.err select,.field.err textarea{border-color:#c0492b;}
.field .msg{display:none;color:#c0492b;font-size:.8rem;margin-top:5px;font-weight:600;}
.field.err .msg{display:block;}
.two{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-foot{display:flex;align-items:center;gap:16px;margin-top:8px;flex-wrap:wrap;}
.form-note{color:var(--text-mute);font-size:.82rem;}
.form-success{display:none;text-align:center;padding:30px 10px;}
.form-success.show{display:block;}
.form-success .ic{width:64px;height:64px;border-radius:50%;background:#1f8a5b;color:#fff;display:grid;place-items:center;margin:0 auto 16px;}
.form-success .ic svg{width:32px;height:32px;}
.form-success h3{font-size:1.5rem;}
.form-success p{color:var(--text-soft);max-width:38ch;margin:6px auto 0;}

/* ============================================================ FOOTER */
.footer{background:#100e0a;color:#cabfad;padding:64px 0 30px;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid var(--paper-line);}
.footer h5{font-family:"Anton",sans-serif;font-weight:400;text-transform:uppercase;letter-spacing:.06em;color:#fff;font-size:1rem;margin:0 0 16px;}
.footer a{color:#bdb29e;display:block;padding:5px 0;font-size:.95rem;transition:color .2s;}
.footer a:hover{color:var(--cedar-soft);}
.footer .blurb{color:#a99e8a;font-size:.95rem;max-width:34ch;margin:16px 0 0;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:24px;flex-wrap:wrap;color:#a99e8a;font-size:.85rem;}
.footer-bottom .site-credit{display:inline;padding:0;color:#bdb29e;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;}
.footer-bottom .badge{display:inline-flex;align-items:center;gap:8px;color:#bdb29e;}
.footer-bottom .badge svg{width:15px;height:15px;color:var(--cedar-soft);}

/* ============================================================ MOBILE NAV */
.mobile-menu{position:fixed;inset:0;z-index:60;background:var(--ink);display:none;flex-direction:column;padding:24px 28px;}
.mobile-menu.open{display:flex;}
.mobile-menu .mm-top{display:flex;align-items:center;justify-content:space-between;height:50px;}
.mobile-menu a{color:#efe7d8;font-family:"Anton",sans-serif;text-transform:uppercase;font-size:2rem;padding:14px 0;border-bottom:1px solid var(--paper-line);}
.mm-close{background:none;border:0;color:#fff;}
.mm-close svg{width:30px;height:30px;}

/* ============================================================ REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}

/* ============================================================ RESPONSIVE */
@media(max-width:1000px){
  .svc-grid{grid-template-columns:repeat(2,1fr);}
  .gallery{columns:2;}
  .about-grid,.areas-grid,.quote-grid{grid-template-columns:1fr;gap:40px;}
  .about-photo{max-width:440px;}
  .nav-links{display:none;}
}
@media(max-width:680px){
  body{font-size:17px;}
  .wrap{padding:0 20px;}
  .band{padding:64px 0;}
  .nav-phone{display:none;}
  .hamburger{display:block;}
  .nav-right .btn{display:none;}
  .svc-grid{grid-template-columns:1fr;}
  .gallery{columns:1;}
  .process{grid-template-columns:1fr;}
  .pstep + .pstep{border-left:0;border-top:2px solid var(--ink);}
  .two{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;gap:28px;}
  .hero{min-height:92vh;}
  .about-badge{right:12px;}
}
