/* ===========================================================
   KAS — Signage & Events design system
   Current theme: LIGHT base + INDIGO primary accent + BLUE glow
   To recolor the WHOLE site, edit ONLY the :root block below.
   Each accent has a matching *-rgb value (used by the glow effects) —
   keep the two in sync when you change a color.
   =========================================================== */
:root{
  --base:#f2f2f2;        /* light grey — main background       */
  --base-rgb:242,242,242;/* same light, for overlays           */
  --base2:#ffffff;       /* white — cards / panels             */
  --line:#d3dae6;        /* borders + technical grid lines     */
  --white:#101935;       /* main text — dark ink               */
  --muted:#5a6378;       /* secondary text                     */

  --accent:#10069f;          /* PRIMARY accent — indigo        */
  --accent-rgb:16,6,159;     /* same indigo, for glows         */
  --accent2:#1560bd;         /* GLOW / highlight — blue        */
  --accent2-rgb:21,96,189;   /* same blue, for glows           */
}

*{box-sizing:border-box}
body{background:var(--base);color:var(--white);
  font-family:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  -webkit-font-smoothing:antialiased;line-height:1.5;overflow-x:hidden;margin:0}
h1,h2,h3,.display{font-family:"Bebas Neue","Inter",sans-serif;font-weight:400;letter-spacing:.02em;line-height:.95;margin:0}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.kas-wrap{max-width:1180px;margin:0 auto;padding:0 1.5rem}

/* technical drafting grid behind dark rows */
.grid-bg{position:relative}
.grid-bg::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:48px 48px;opacity:.18;
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,#000 40%,transparent 100%);
  mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,#000 40%,transparent 100%)}
.grid-bg>*{position:relative;z-index:1}

/* buttons with neon glow */
.kas-btn{display:inline-block;background:var(--accent);color:#fff;font-weight:700;
  padding:.85rem 1.7rem;border-radius:6px;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;
  transition:box-shadow .25s,transform .15s;cursor:pointer;border:0}
.kas-btn:hover{transform:translateY(-1px);box-shadow:0 0 0 1px var(--accent),0 0 25px rgba(var(--accent-rgb),.55)}
.kas-btn.ghost{background:transparent;color:var(--white);border:1px solid var(--line)}
.kas-btn.ghost:hover{border-color:var(--accent2);box-shadow:0 0 22px rgba(var(--accent2-rgb),.35)}

/* top guide line (scroll progress) */
.kas-guide{position:fixed;top:0;left:0;width:100%;height:3px;z-index:9999;background:transparent}
.kas-guide i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent2));box-shadow:0 0 12px rgba(var(--accent-rgb),.7)}

/* NAV */
.kas-nav{position:sticky;top:0;z-index:500;background:rgba(var(--base-rgb),.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.kas-nav .kas-wrap{display:flex;align-items:center;justify-content:space-between;height:88px}
.kas-logo{display:inline-flex;align-items:center;gap:10px;font-family:"Bebas Neue";font-size:1.7rem;letter-spacing:.08em;color:var(--white);text-decoration:none}
.kas-logo-mark{height:68px;width:auto;display:block;flex:0 0 auto}
.kas-logo b{color:var(--accent)}
.kas-navlinks{display:flex;gap:2rem;font-size:.85rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.kas-navlinks a:hover{color:var(--white)}
.kas-nav .kas-btn{padding:.6rem 1.2rem}

/* HERO */
.kas-hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden}
.kas-hero-bg{position:absolute;inset:0;z-index:0}
.kas-hero-bg .pane{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.4s ease}
.kas-hero-bg .pane.on{opacity:1}
.pane.a{background:radial-gradient(circle at 70% 30%,rgba(var(--accent-rgb),.12),transparent 55%),linear-gradient(135deg,#f7f9fc,#eef2f8 60%,#e7edf6)}
.pane.b{background:radial-gradient(circle at 30% 70%,rgba(var(--accent2-rgb),.14),transparent 55%),linear-gradient(135deg,#f7f9fc,#eaf1fb 60%,#e3edf9)}
.kas-hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(var(--base-rgb),.92),rgba(var(--base-rgb),.55) 55%,transparent)}
.kas-hero .kas-wrap{position:relative;z-index:2}
.kicker{display:inline-flex;align-items:center;gap:.6rem;color:var(--accent);font-size:.8rem;text-transform:uppercase;letter-spacing:.2em;margin-bottom:1.4rem}
.kicker::before{content:"";width:30px;height:2px;background:var(--accent)}
.kicker.cyan{color:var(--accent2)} .kicker.cyan::before{background:var(--accent2)}
.kas-hero h1{font-size:clamp(2.8rem,7vw,6rem);max-width:20ch}
.kas-hero h1 em{font-style:normal;color:var(--accent)}
.kas-hero h1 em.cyan{color:var(--accent2)}
.kas-hero p{color:var(--muted);font-size:1.15rem;max-width:48ch;margin:1.6rem 0 2.4rem}
.kas-cta-row{display:flex;gap:1rem;flex-wrap:wrap}

/* SECTIONS */
.kas-sec{padding:7rem 0}
.sec-head{max-width:62ch;margin-bottom:3rem}
.sec-head h2{font-size:clamp(2.2rem,4.5vw,3.6rem)}
.sec-head p{color:var(--muted);margin-top:1rem;font-size:1.05rem}

/* ABOUT */
.kas-about{display:grid;grid-template-columns:1.5fr 1fr;gap:3rem;align-items:center}
.kas-about-copy h2{font-size:clamp(2.2rem,4.5vw,3.6rem);margin-bottom:1.2rem}
.kas-about-copy p{color:var(--muted);font-size:1.08rem;margin:0 0 1rem;max-width:54ch}
.kas-about-card{background:var(--base2);border:1px solid var(--line);border-radius:14px;padding:2rem 1.9rem;
  box-shadow:0 14px 40px rgba(var(--accent-rgb),.06)}
.kas-about-points{list-style:none;margin:0;padding:0}
.kas-about-points li{position:relative;padding:0 0 1.1rem 2rem;color:var(--white);font-size:1.02rem;line-height:1.4}
.kas-about-points li:last-child{padding-bottom:0}
.kas-about-points li::before{content:"";position:absolute;left:0;top:.05em;width:1.15rem;height:1.15rem;border-radius:50%;
  background:rgba(var(--accent-rgb),.12);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath d='M1 5l2.5 2.5L9 2' fill='none' stroke='%2310069f' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center}
@media(max-width:900px){.kas-about{grid-template-columns:1fr;gap:2rem}}

/* SERVICE CARDS */
.kas-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.kas-card{background:var(--base2);border:1px solid var(--line);border-radius:12px;padding:1.8rem 1.6rem;
  transition:border-color .25s,box-shadow .3s,transform .2s;min-height:230px;display:flex;flex-direction:column}
.kas-card .ico{width:46px;height:46px;border-radius:9px;display:grid;place-items:center;margin-bottom:1.2rem;
  background:rgba(var(--accent-rgb),.12);color:var(--accent);font-size:1.3rem;font-weight:800}
.kas-card h3{font-size:1.5rem;margin-bottom:.5rem;letter-spacing:.03em}
.kas-card p{color:var(--muted);font-size:.92rem}
.kas-card:hover{transform:translateY(-6px);border-color:var(--accent);
  box-shadow:0 14px 40px rgba(0,0,0,.5),0 0 0 1px var(--accent),0 0 30px rgba(var(--accent-rgb),.35)}
/* alternate cards glow with the secondary accent (uses both colors) */
.kas-card:nth-child(even) .ico{background:rgba(var(--accent2-rgb),.12);color:var(--accent2)}
.kas-card:nth-child(even):hover{border-color:var(--accent2);box-shadow:0 14px 40px rgba(0,0,0,.5),0 0 0 1px var(--accent2),0 0 30px rgba(var(--accent2-rgb),.35)}

/* PROOF GALLERY */
.kas-gallery{columns:3;column-gap:1rem}
.shot{break-inside:avoid;margin-bottom:1rem;border-radius:12px;overflow:hidden;position:relative;border:1px solid var(--line);display:block;width:100%}
/* tiles that open a gallery are <button> — strip native button chrome */
button.shot{padding:0;background:none;font:inherit;text-align:left;color:inherit;-webkit-appearance:none;appearance:none}
.shot.has-gallery{cursor:pointer}
.shot img{width:100%;height:auto;display:block}
/* caption: always-visible bottom scrim with white text (readable over any photo) */
.shot .cap{position:absolute;left:0;right:0;bottom:0;padding:2.4rem 1rem .9rem;color:#fff;
  background:linear-gradient(transparent,rgba(8,12,24,.88));z-index:1}
.shot .cap .cap-t{display:block;font-size:.92rem;font-weight:600;line-height:1.25;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.shot .cap .cap-n{display:inline-flex;align-items:center;gap:.35rem;margin-top:.35rem;font-size:.72rem;
  text-transform:uppercase;letter-spacing:.1em;color:#cfe0f5;opacity:.85;transition:opacity .25s}
.shot .cap .cap-n::before{content:"\25F1";font-size:.9em}
.shot:hover .cap .cap-n{opacity:1}
/* "+N" badge showing how many photos are in the category */
.shot-badge{position:absolute;top:.7rem;right:.7rem;z-index:2;background:rgba(var(--accent-rgb),.92);color:#fff;
  font-size:.72rem;font-weight:700;letter-spacing:.02em;padding:.22rem .55rem;border-radius:999px;box-shadow:0 2px 8px rgba(0,0,0,.25)}
.shot:hover{box-shadow:0 0 0 1px var(--accent),0 0 30px rgba(var(--accent-rgb),.3)}
.shot:nth-child(3n+2):hover{box-shadow:0 0 0 1px var(--accent2),0 0 30px rgba(var(--accent2-rgb),.3)}
.shot.has-gallery:hover img{transform:scale(1.03)}
.shot.has-gallery img{transition:transform .4s ease}

/* GALLERY POPUP (per-category) */
.kas-gallery-dialog{max-width:1060px}
.kas-gallery-dialog h3{font-size:1.8rem;margin-bottom:.2rem}
.kas-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.7rem;margin-top:1.2rem}
.kas-gallery-grid a{display:block;border-radius:9px;overflow:hidden;border:1px solid var(--line);line-height:0}
.kas-gallery-grid img{width:100%;height:188px;object-fit:cover;transition:transform .35s ease}
.kas-gallery-grid a:hover img{transform:scale(1.06)}
.ph{height:240px;background:linear-gradient(135deg,#e8edf5,#dde4ef)}
.ph.tall{height:340px}.ph.m{background:linear-gradient(135deg,#e9ecf6,#dde2f2)}.ph.c{background:linear-gradient(135deg,#e6eef7,#d9e6f5)}

/* STATS */
.kas-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:3rem 0}
.stat .n{font-family:"Bebas Neue";font-size:3rem;color:var(--accent);line-height:1}
.stat:nth-child(even) .n{color:var(--accent2)}
.stat .l{color:var(--muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;margin-top:.3rem}

/* CTA + FOOTER */
.kas-final{text-align:center;padding:7rem 1.5rem;border-top:1px solid var(--line)}
.kas-final h2{font-size:clamp(2.4rem,5vw,4rem)}
.kas-final p{color:var(--muted);margin:1rem auto 2rem;max-width:46ch}
.kas-foot{border-top:1px solid var(--line);padding:2.5rem 0;color:var(--muted);font-size:.85rem}
.kas-foot .kas-wrap{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.kas-foot-logo{height:64px;width:auto;flex:0 0 auto}

/* CLIENTS marquee */
.kas-clients{padding:5rem 0;overflow:hidden}
.kas-clients .sec-head{margin-left:auto;margin-right:auto;margin-bottom:2.5rem}
.kas-marquee{position:relative;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent)}
.kas-track{display:flex;gap:4rem;align-items:center;width:max-content;animation:kas-scroll 38s linear infinite}
.kas-marquee:hover .kas-track{animation-play-state:paused}
@keyframes kas-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.kas-client-item{flex:0 0 auto;display:flex;align-items:center;height:50px;opacity:.55;transition:opacity .25s}
.kas-client-item img{height:50px;width:auto;max-width:190px;object-fit:contain;filter:brightness(0) invert(1)}
.kas-client-item:hover{opacity:1}
.kas-client-item:hover img{filter:none}
.kas-client-name{font-family:"Bebas Neue";font-size:2rem;letter-spacing:.08em;color:var(--muted);white-space:nowrap;transition:color .25s}
.kas-client-item:hover .kas-client-name{color:var(--white)}
@media(prefers-reduced-motion:reduce){.kas-track{animation:none;flex-wrap:wrap;justify-content:center}}

/* CONTACT */
/* Top row: contact info + map side by side */
.kas-contact-top{display:grid;grid-template-columns:1fr 1.4fr;gap:2rem;max-width:980px;margin:3rem auto 0;text-align:left;align-items:stretch}
/* Centered button that opens the quote modal */
.kas-contact-cta{margin-top:2.5rem}
.kas-contact-info h3{font-size:1.8rem;margin-bottom:1.2rem}
.kas-contact-list{list-style:none;margin:0;padding:0}
.kas-contact-list li{margin-bottom:1.2rem}
.kas-contact-list span{display:block;color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:.2rem}
.kas-contact-list a{color:var(--white);font-size:1.05rem;text-decoration:none}
.kas-contact-list a:hover{color:var(--accent)}

/* Contact Form 7 — themed to match */
.kas-form .wpcf7-form label{display:block;margin-bottom:1rem;color:var(--muted);font-size:.85rem}
.kas-form .wpcf7-form input,
.kas-form .wpcf7-form textarea{width:100%;margin-top:.4rem;background:var(--base);
  border:1px solid var(--line);border-radius:6px;padding:.8rem .9rem;color:var(--white);font-family:inherit;font-size:1rem}
.kas-form .wpcf7-form input::placeholder,
.kas-form .wpcf7-form textarea::placeholder{color:#5e6f88}
.kas-form .wpcf7-form input:focus,
.kas-form .wpcf7-form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.kas-form .wpcf7-form textarea{min-height:130px;resize:vertical}
.kas-form .wpcf7-submit{background:var(--accent);color:#fff;font-weight:700;border:0;border-radius:6px;
  padding:.85rem 1.8rem;text-transform:uppercase;letter-spacing:.08em;font-size:.85rem;cursor:pointer;
  transition:box-shadow .25s,transform .15s;width:auto}
.kas-form .wpcf7-submit:hover{transform:translateY(-1px);box-shadow:0 0 0 1px var(--accent),0 0 25px rgba(var(--accent-rgb),.55)}
.kas-form .wpcf7-not-valid-tip{color:#ff8080;font-size:.78rem;margin-top:.3rem}
.kas-form .wpcf7-response-output{border-radius:6px;padding:.7rem 1rem !important;margin:1rem 0 0 !important;font-size:.9rem}

/* MAP (sits in the contact top row, fills its cell height) */
.kas-map{border:1px solid var(--line);border-radius:12px;overflow:hidden;line-height:0;min-height:300px}
.kas-map iframe{width:100%;height:100%;min-height:300px;border:0;display:block}

/* MODAL (quote form popup) */
body.kas-noscroll{overflow:hidden}
.kas-modal{position:fixed;inset:0;z-index:1000;display:none}
.kas-modal.open{display:block}
.kas-modal-backdrop{position:absolute;inset:0;background:rgba(7,12,22,.78);backdrop-filter:blur(4px)}
.kas-modal-dialog{position:relative;z-index:1;max-width:560px;margin:6vh auto;background:var(--base2);
  border:1px solid var(--line);border-radius:16px;padding:2.4rem 2.1rem;max-height:88vh;overflow:auto;text-align:left;
  box-shadow:0 30px 80px rgba(0,0,0,.6)}
.kas-modal.open .kas-modal-dialog{animation:kas-pop .25s ease}
@keyframes kas-pop{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.kas-modal-x{position:absolute;top:10px;right:16px;background:none;border:0;color:var(--muted);font-size:2rem;line-height:1;cursor:pointer;padding:0}
.kas-modal-x:hover{color:var(--accent)}
.kas-modal-dialog h3{font-size:2rem;margin-bottom:.3rem}
.kas-modal-dialog>p{color:var(--muted);margin-bottom:1.4rem;font-size:.95rem}
@media(max-width:560px){.kas-modal-dialog{margin:0;min-height:100%;border-radius:0}}
/* success panel shown after a sent form */
.kas-thanks{position:absolute;inset:0;background:var(--base2);border-radius:16px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;padding:2rem;animation:kas-pop .25s ease}
.kas-thanks-ic{width:64px;height:64px;border-radius:50%;background:rgba(var(--accent-rgb),.15);color:var(--accent);
  display:grid;place-items:center;font-size:2rem;margin-bottom:.8rem}
.kas-thanks h3{font-size:2rem;margin-bottom:.3rem}
.kas-thanks p{color:var(--muted);max-width:32ch}

/* reveal on scroll */
.rv{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.rv.in{opacity:1;transform:none}

@media(max-width:900px){.kas-cards{grid-template-columns:repeat(2,1fr)}.kas-gallery{columns:2}.kas-stats{grid-template-columns:repeat(2,1fr);gap:1.5rem}.kas-contact-top{grid-template-columns:1fr}}
@media(max-width:560px){.kas-cards{grid-template-columns:1fr}.kas-gallery{columns:1}.kas-navlinks{display:none}}
