/* =========================================================================
   Classique Security — main stylesheet
   ========================================================================= */
:root{
  --bg:#0B0C0E; --bg-2:#101216; --panel:#16191F; --panel-2:#1C2027;
  --line:rgba(255,255,255,.09); --line-strong:rgba(255,255,255,.16);
  --text:#F3F4F6; --muted:#9AA1AB; --muted-2:#6E747E;
  --accent:#B11622; --accent-soft:rgba(177,22,34,.16); --cta:#CFA646; --cta-hover:#dcba6c; --cta-ink:#1A1305;
  --ok:#5BD08A; --maxw:1160px; --r:14px; --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--text);font-family:"Inter",system-ui,sans-serif;line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
svg{width:18px;height:18px}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}

.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--accent);color:#fff;padding:10px 16px;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}

.display{font-family:"Saira Condensed",sans-serif;font-weight:800;line-height:.95;letter-spacing:-.01em;text-transform:uppercase}
.eyebrow{font-family:"Saira Semi Condensed",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;color:var(--accent);display:inline-flex;align-items:center;gap:9px}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--accent);opacity:.7}
.sec-h2{font-size:clamp(2rem,5vw,3.1rem);margin-top:16px}
.muted-p{color:var(--muted);margin-top:16px}
.mt-26{margin-top:26px}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:"Saira Semi Condensed",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:.92rem;padding:14px 22px;border-radius:10px;cursor:pointer;border:1px solid transparent;transition:transform .2s var(--ease),background .2s,border-color .2s,color .2s;white-space:nowrap}
.btn-gold{background:var(--cta);color:var(--cta-ink)}
.btn-gold:hover{transform:translateY(-2px);background:var(--cta-hover)}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.btn-login{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-login:hover{transform:translateY(-2px);filter:brightness(1.14)}
.btn-login svg{width:17px;height:17px}
.btn svg{width:17px;height:17px}
.ic-sm{width:16px;height:16px}

/* topbar */
.topbar{background:#070809;border-bottom:1px solid var(--line);font-size:.8rem;color:var(--muted)}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;min-height:38px}
.topbar a,.topbar .tb-loc{display:inline-flex;align-items:center;gap:7px}
.topbar a:hover{color:var(--accent)}
.topbar svg{width:14px;height:14px;color:var(--accent)}
.topbar .tb-right{display:flex;gap:20px}
@media(max-width:720px){.topbar .tb-loc{display:none}.topbar .wrap{justify-content:center}}

/* header */
#masthead{position:sticky;top:0;z-index:60;background:rgba(11,12,14,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);transition:background .3s}
#masthead.scrolled{background:rgba(8,9,11,.94)}
.nav{display:flex;align-items:center;justify-content:space-between;min-height:74px;gap:16px}
.brand{display:flex;align-items:center;gap:11px;flex-shrink:0}
.brand img,.custom-logo{height:40px;width:auto;max-width:240px;object-fit:contain}
.brand .custom-logo-link{display:block;line-height:0}
.fallback{font-family:"Saira Condensed",sans-serif;font-weight:800;font-size:1.35rem;letter-spacing:.02em;color:var(--text)}
.fallback span{color:var(--accent)}

/* primary menu */
nav.main .menu{list-style:none;display:flex;align-items:center;gap:2px}
nav.main .menu > li{position:relative}
nav.main .menu a{font-family:"Saira Semi Condensed",sans-serif;font-weight:600;font-size:.92rem;letter-spacing:.03em;padding:10px 14px;border-radius:8px;color:var(--muted);transition:color .2s,background .2s;display:inline-flex;align-items:center;gap:5px}
nav.main .menu > li:hover > a,nav.main .menu a:hover{color:var(--text);background:rgba(255,255,255,.04)}
nav.main .menu > li.current-menu-item > a{color:var(--text)}
nav.main .menu .sub-menu{list-style:none;position:absolute;top:calc(100% + 6px);left:0;min-width:230px;background:var(--panel);border:1px solid var(--line-strong);border-radius:12px;padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.22s var(--ease);box-shadow:0 24px 60px rgba(0,0,0,.5);z-index:5}
nav.main .menu > li:hover > .sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
nav.main .menu .sub-menu a{display:block;padding:9px 12px;font-size:.88rem;border-radius:7px}
nav.main .menu .sub-menu a:hover{background:var(--accent-soft);color:var(--accent)}
nav.main .menu .menu-item-has-children > a::after{content:"";width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);margin-left:3px;opacity:.7}

.nav-cta{display:flex;align-items:center;gap:12px}
.nav-cta .btn{padding:11px 18px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:26px;height:2px;background:var(--text);transition:.3s;display:block}

@media(max-width:1040px){nav.main,.nav-cta .btn-ghost,.nav-cta .btn-login{display:none}.burger{display:flex}}

/* mobile drawer */
.drawer{position:fixed;inset:0 0 0 auto;width:min(88%,360px);z-index:80;background:var(--bg-2);border-left:1px solid var(--line-strong);transform:translateX(100%);transition:transform .35s var(--ease);padding:26px 22px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.drawer.open{transform:translateX(0)}
.scrim{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:70;opacity:0;visibility:hidden;transition:.3s}
.scrim.open{opacity:1;visibility:visible}
.drawer-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.drawer-close{background:none;border:0;color:var(--muted);font-size:1.9rem;cursor:pointer;line-height:1}
.drawer .drawer-menu{list-style:none}
.drawer .drawer-menu li{position:relative;border-bottom:1px solid var(--line)}
.drawer .drawer-menu a{display:block;padding:13px 8px;font-family:"Saira Semi Condensed",sans-serif;font-weight:600;font-size:1.05rem;color:var(--text)}
.drawer .drawer-menu .sub-menu{list-style:none;display:none;padding-bottom:8px}
.drawer .drawer-menu li.open > .sub-menu{display:block}
.drawer .drawer-menu .sub-menu li{border:0}
.drawer .drawer-menu .sub-menu a{padding:9px 8px 9px 20px;font-size:.92rem;color:var(--muted);font-weight:500}
.drawer .drawer-menu .sub-menu a:hover{color:var(--accent)}
.submenu-toggle{position:absolute;right:4px;top:8px;width:34px;height:34px;background:none;border:0;color:var(--accent);font-size:1.3rem;cursor:pointer}
.drawer .btn{margin-top:14px}
.drawer .btn:first-of-type{margin-top:20px}

/* scan line */
.scan{position:absolute;left:0;right:0;top:0;height:2px;z-index:1;background:linear-gradient(90deg,transparent,rgba(216,169,75,.6),transparent);animation:scan 7s linear infinite}
@keyframes scan{0%{transform:translateY(0);opacity:0}8%{opacity:1}92%{opacity:1}100%{transform:translateY(70vh);opacity:0}}

/* hero */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.30;filter:grayscale(.3) contrast(1.05)}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,12,14,.55),rgba(11,12,14,.82) 55%,var(--bg)),radial-gradient(900px 500px at 75% 0%,rgba(216,169,75,.10),transparent 60%)}
.hero-inner{position:relative;z-index:2;padding:74px 0 86px}
.status{display:inline-flex;align-items:center;gap:9px;background:rgba(91,208,138,.08);border:1px solid rgba(91,208,138,.3);border-radius:100px;padding:7px 15px;font-family:"Saira Semi Condensed",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:#aef0c6;margin-bottom:26px}
.dot{width:9px;height:9px;border-radius:50%;background:var(--ok);position:relative}
.dot::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:1px solid var(--ok);animation:pulse 2s ease-out infinite}
@keyframes pulse{0%{transform:scale(.6);opacity:.9}100%{transform:scale(1.8);opacity:0}}
.hero h1{font-size:clamp(2.7rem,8.5vw,5.6rem);max-width:14ch}
.hero .lead{font-size:clamp(1.02rem,2.4vw,1.22rem);color:var(--muted);max-width:54ch;margin:22px 0 32px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px}
.hero-stats{display:flex;flex-wrap:wrap;gap:38px;margin-top:54px;padding-top:30px;border-top:1px solid var(--line)}
.stat .n{font-family:"Saira Condensed",sans-serif;font-weight:800;font-size:2.3rem;line-height:1}
.stat .l{font-family:"Saira Semi Condensed",sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;color:var(--muted-2);margin-top:7px}

/* trust strip */
.trust{background:var(--bg-2);border-bottom:1px solid var(--line)}
.trust .wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px;padding:18px 20px}
.trust .item{display:flex;align-items:center;gap:10px;font-family:"Saira Semi Condensed",sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;color:var(--muted)}
.trust .item svg{width:18px;height:18px;color:var(--accent);flex-shrink:0}

/* section */
section.block{padding:84px 0;border-bottom:1px solid var(--line)}
.sec-head{max-width:62ch}
.sec-head h2{font-size:clamp(2rem,5vw,3.1rem);margin:16px 0 0}
.sec-head p{color:var(--muted);margin-top:18px;font-size:1.05rem}
.center{text-align:center;margin:0 auto}
.center-eb{margin:0 auto}
.center-p{margin-left:auto;margin-right:auto}

/* about */
.about-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center}
.about-copy p{color:var(--muted);margin-top:18px}
.about-copy p.lead-p{color:var(--text);font-size:1.12rem}
.about-media{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line-strong);aspect-ratio:4/5}
.about-media img{width:100%;height:100%;object-fit:cover}
.about-media .badge{position:absolute;left:18px;bottom:18px;background:rgba(11,12,14,.85);backdrop-filter:blur(6px);border:1px solid var(--line-strong);border-radius:12px;padding:14px 18px}
.about-media .badge .b1{font-family:"Saira Condensed",sans-serif;font-weight:800;font-size:1.9rem;line-height:1;color:var(--accent)}
.about-media .badge .b2{font-family:"Saira Semi Condensed",sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;color:var(--muted);margin-top:5px}

/* services */
.svc-groups{display:flex;flex-direction:column;gap:46px;margin-top:48px}
.svc-group-title{font-family:"Saira Semi Condensed",sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:.82rem;color:var(--accent);display:flex;align-items:center;gap:12px;margin-bottom:20px}
.svc-group-title::after{content:"";flex:1;height:1px;background:var(--line)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.svc{display:flex;align-items:center;gap:14px;padding:18px;border:1px solid var(--line);border-radius:12px;background:var(--panel);transition:.22s var(--ease);position:relative;overflow:hidden}
.svc::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform .25s var(--ease)}
.svc:hover{transform:translateY(-3px);border-color:var(--line-strong);background:var(--panel-2)}
.svc:hover::before{transform:scaleY(1)}
.svc .ic{width:42px;height:42px;border-radius:10px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.svc .ic svg{width:21px;height:21px;color:var(--accent)}
.svc .t{font-family:"Saira Semi Condensed",sans-serif;font-weight:600;font-size:1.02rem}
.svc .arrow{width:16px;height:16px;margin-left:auto;color:var(--muted-2);opacity:0;transition:.2s}
.svc:hover .arrow{opacity:1;color:var(--accent);transform:translateX(2px)}

/* why */
.why{display:grid;grid-template-columns:.95fr 1.05fr;gap:54px;align-items:center}
.why-media{border-radius:var(--r);overflow:hidden;border:1px solid var(--line-strong)}
.why-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:28px}
.feat{padding:18px;border:1px solid var(--line);border-radius:12px;background:var(--panel)}
.feat .ic{width:38px;height:38px;border-radius:9px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.feat .ic svg{width:19px;height:19px;color:var(--accent)}
.feat h4{font-family:"Saira Semi Condensed",sans-serif;font-weight:600;font-size:1rem}
.feat p{color:var(--muted);font-size:.88rem;margin-top:5px}

/* testimonials */
.tcards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
.tcard{padding:28px;border:1px solid var(--line);border-radius:var(--r);background:var(--panel)}
.tcard .quote{font-family:"Saira Condensed",sans-serif;font-weight:800;font-size:3rem;color:var(--accent);opacity:.25;line-height:.6;height:24px}
.tcard p{color:var(--muted);margin:14px 0 20px;font-size:.96rem}
.tcard .who{display:flex;align-items:center;gap:12px}
.tcard .who .av{width:40px;height:40px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-family:"Saira Condensed",sans-serif;font-weight:800}
.tcard .who .nm{font-family:"Saira Semi Condensed",sans-serif;font-weight:600}
.tcard .stars{color:var(--accent);font-size:.85rem;letter-spacing:2px}

/* team */
.team-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;max-width:620px;margin:48px auto 0}
.member{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--panel)}
.member .ph{aspect-ratio:1/1;overflow:hidden}
.member .ph img{width:100%;height:100%;object-fit:cover;filter:grayscale(.15)}
.member .info{padding:20px;text-align:center}
.member .info .nm{font-family:"Saira Condensed",sans-serif;font-weight:800;font-size:1.5rem;text-transform:uppercase}
.member .info .role{font-family:"Saira Semi Condensed",sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;color:var(--accent);margin-top:6px}

/* contact */
.contact{background:var(--bg-2)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
.contact-h2{font-size:clamp(2rem,5vw,3rem);margin-top:16px}
.contact-copy .lead{color:var(--muted);margin-top:18px;font-size:1.05rem}
.cinfo{margin-top:34px;display:flex;flex-direction:column;gap:16px}
.cinfo a,.cinfo .ci{display:flex;align-items:center;gap:15px;padding:16px;border:1px solid var(--line);border-radius:12px;background:var(--panel);transition:.2s}
.cinfo a:hover{border-color:var(--accent);transform:translateX(3px)}
.cinfo .ic{width:44px;height:44px;border-radius:10px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cinfo .ic svg{width:21px;height:21px;color:var(--accent)}
.cinfo .lbl{font-family:"Saira Semi Condensed",sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;color:var(--muted-2);display:block}
.cinfo .val{font-family:"Saira Semi Condensed",sans-serif;font-weight:600;font-size:1.1rem;margin-top:2px;display:block}

.form{background:var(--panel);border:1px solid var(--line-strong);border-radius:var(--r);padding:30px}
.form h3{font-family:"Saira Condensed",sans-serif;font-weight:800;font-size:1.7rem;text-transform:uppercase}
.form .form-sub{color:var(--muted);font-size:.9rem;margin:6px 0 22px}
.field{margin-bottom:15px}
.field label{display:block;font-family:"Saira Semi Condensed",sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;color:var(--muted);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;background:var(--bg);border:1px solid var(--line-strong);border-radius:9px;padding:13px 14px;color:var(--text);font-family:"Inter",sans-serif;font-size:.95rem;text-transform:none;letter-spacing:normal;transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.field textarea{resize:vertical;min-height:90px}
.form .form-btn{width:100%;margin-top:8px}
.clsq-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-status{font-family:"Saira Semi Condensed",sans-serif;font-size:.9rem;margin-top:14px;text-align:center;display:none}
.form-status.ok,.form-status.err{display:block}
.form-status.ok{color:var(--ok)}
.form-status.err{color:#ff8a8a}
.form .form-note{color:var(--muted-2);font-size:.78rem;margin-top:14px;text-align:center}

/* page hero (inner pages) */
.page-hero{position:relative;overflow:hidden;background:var(--bg-2);border-bottom:1px solid var(--line);padding:64px 0}
.page-hero h1{font-size:clamp(2.2rem,6vw,3.6rem);margin-top:14px}

/* entry content (pages & posts) */
.entry-content{max-width:75ch;font-size:1.05rem;color:#d9dde2}
.article-narrow{max-width:820px}
.entry-content > *{margin-bottom:1.1em}
.entry-content h2{font-family:"Saira Condensed",sans-serif;font-weight:800;text-transform:uppercase;font-size:2rem;margin:1.6em 0 .5em;color:var(--text)}
.entry-content h3{font-family:"Saira Semi Condensed",sans-serif;font-weight:700;font-size:1.4rem;margin:1.4em 0 .4em;color:var(--text)}
.entry-content h4{font-family:"Saira Semi Condensed",sans-serif;font-weight:600;font-size:1.15rem;margin:1.2em 0 .3em;color:var(--text)}
.entry-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.entry-content ul,.entry-content ol{padding-left:1.4em}
.entry-content li{margin-bottom:.5em}
.entry-content ul li::marker{color:var(--accent)}
.entry-content img{border-radius:var(--r);border:1px solid var(--line)}
.entry-content blockquote{border-left:3px solid var(--accent);padding:8px 0 8px 20px;color:var(--muted);font-size:1.15rem}
.entry-content table{width:100%;border-collapse:collapse}
.entry-content th,.entry-content td{border:1px solid var(--line);padding:10px 12px;text-align:left}
.entry-content .wp-block-button__link,.entry-content .button{display:inline-block;background:var(--cta);color:var(--cta-ink);padding:13px 22px;border-radius:10px;text-decoration:none;font-family:"Saira Semi Condensed",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.post-thumb{margin-bottom:32px;border-radius:var(--r);overflow:hidden;border:1px solid var(--line)}
.post-meta{margin-top:30px;color:var(--muted-2);font-size:.9rem}
.post-meta a{color:var(--accent)}
.post-nav{display:flex;justify-content:space-between;gap:16px;margin-top:24px;border-top:1px solid var(--line);padding-top:22px;font-family:"Saira Semi Condensed",sans-serif}
.post-nav a{color:var(--muted)}.post-nav a:hover{color:var(--accent)}

/* blog grid */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.post-card{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--panel);transition:.22s var(--ease)}
.post-card:hover{transform:translateY(-3px);border-color:var(--line-strong)}
.pc-thumb img{width:100%;aspect-ratio:16/10;object-fit:cover}
.pc-body{padding:22px}
.pc-date{font-family:"Saira Semi Condensed",sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;color:var(--muted-2)}
.pc-title{font-family:"Saira Condensed",sans-serif;font-weight:800;font-size:1.4rem;line-height:1.1;margin:8px 0 10px;text-transform:uppercase}
.pc-title a:hover{color:var(--accent)}
.pc-excerpt{color:var(--muted);font-size:.92rem}
.pc-more{display:inline-block;margin-top:14px;color:var(--accent);font-family:"Saira Semi Condensed",sans-serif;font-weight:600}
.pagination{margin-top:44px}
.pagination .page-numbers{display:inline-flex;min-width:42px;height:42px;align-items:center;justify-content:center;padding:0 12px;border:1px solid var(--line-strong);border-radius:9px;margin:0 4px;color:var(--muted);font-family:"Saira Semi Condensed",sans-serif}
.pagination .page-numbers.current,.pagination .page-numbers:hover{background:var(--cta);color:var(--cta-ink);border-color:var(--cta)}

/* comments (light) */
.comments-wrap{padding-bottom:60px}
.comment-list{list-style:none;padding:0}
.comment-body{border:1px solid var(--line);border-radius:12px;padding:18px;margin-bottom:14px;background:var(--panel)}
.comment-form input,.comment-form textarea{width:100%;background:var(--bg);border:1px solid var(--line-strong);border-radius:9px;padding:12px;color:var(--text);margin-bottom:12px}
.comment-form .submit{background:var(--cta);color:var(--cta-ink);border:0;padding:13px 22px;border-radius:10px;cursor:pointer;font-family:"Saira Semi Condensed",sans-serif;font-weight:600;text-transform:uppercase}

/* footer */
#colophon{background:#070809;padding:60px 0 0}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid var(--line)}
.foot-brand img,.foot-brand .custom-logo{height:42px;margin-bottom:18px}
.foot-brand p{color:var(--muted);font-size:.92rem;max-width:34ch}
.foot-social{display:flex;gap:10px;margin-top:20px}
.foot-social a{width:40px;height:40px;border:1px solid var(--line-strong);border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:.2s}
.foot-social a:hover{color:var(--accent);border-color:var(--accent)}
.foot-col h5{font-family:"Saira Semi Condensed",sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;color:var(--accent);margin-bottom:16px}
.foot-col a,.foot-col .fi,.foot-col .foot-menu a{display:block;color:var(--muted);font-size:.92rem;padding:6px 0;transition:.15s}
.foot-col a:hover,.foot-col .foot-menu a:hover{color:var(--text)}
.foot-col .foot-menu{list-style:none}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;padding:22px 0;color:var(--muted-2);font-size:.82rem}
.foot-bottom .lic{display:flex;gap:18px;flex-wrap:wrap}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:1040px){
  .about-grid,.why,.contact-grid{grid-template-columns:1fr;gap:40px}
  .svc-grid{grid-template-columns:1fr 1fr}
  .tcards,.post-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:34px}
}
@media(max-width:640px){
  section.block{padding:60px 0}
  .hero-inner{padding:54px 0 64px}
  .hero-stats{gap:26px}
  .stat .n{font-size:1.9rem}
  .svc-grid,.feat-grid,.tcards,.post-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr;max-width:340px}
  .foot-grid{grid-template-columns:1fr;gap:30px}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%}
  .form{padding:22px}
  .page-hero{padding:48px 0}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ---------------------------------------------------------------------------
   Resilience: keep link-based components legible even if another plugin
   (e.g. Elementor's global kit styles) sets a site-wide <a> colour.
   Tag+class selectors here outrank a bare global "a { color: … }" rule.
   --------------------------------------------------------------------------- */
a.svc,
a.svc .t{color:var(--text)}
a.svc:hover .t{color:var(--text)}
a.btn-ghost{color:var(--text)}
a.btn-ghost:hover{color:var(--accent)}
a.btn-login{color:#fff}
a.btn-gold{color:var(--cta-ink)}
.topbar a,.topbar .tb-loc{color:var(--muted)}
.topbar a:hover{color:var(--accent)}
.cinfo a,.cinfo a .val{color:var(--text)}
.cinfo a .lbl{color:var(--muted-2)}
.foot-col a,.foot-col .foot-menu a{color:var(--muted)}
.foot-col a:hover,.foot-col .foot-menu a:hover{color:var(--text)}
nav.main .menu a{color:var(--muted)}
nav.main .menu > li:hover > a,nav.main .menu a:hover{color:var(--text)}
.pc-title a{color:var(--text)}
.pc-title a:hover{color:var(--accent)}

/* ---------------------------------------------------------------------------
   Quote modal
   --------------------------------------------------------------------------- */
.quote-modal{position:fixed;inset:0;z-index:120;display:none}
.quote-modal.open{display:block}
.quote-modal__scrim{position:absolute;inset:0;background:rgba(0,0,0,.66)}
.quote-modal__dialog.form{position:relative;z-index:1;width:min(94%,560px);margin:6vh auto;max-height:88vh;overflow:auto;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.quote-modal__close{position:absolute;top:10px;right:14px;background:none;border:0;color:var(--muted);font-size:2rem;line-height:1;cursor:pointer;z-index:2}
.quote-modal__close:hover{color:var(--accent)}
.clsq-quote-form .field label{display:block}
body.quote-open{overflow:hidden}
@media(max-width:640px){
  .quote-modal__dialog.form{width:100%;margin:0;min-height:100vh;max-height:100vh;border-radius:0}
}
