:root {
  --ink: #142a25;
  --deep: #0c2822;
  --forest: #17473c;
  --sage: #dfe9df;
  --lime: #c8ee58;
  --paper: #f5f3ed;
  --white: #fff;
  --muted: #63736e;
  --line: #d8ddd7;
  --orange: #e36c3c;
  --font-display: "Manrope", sans-serif;
  --font-body: "DM Sans", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 84px; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: var(--font-body); line-height: 1.55; }
body:not(.admin-body):not(.login-body) { overflow-x: hidden; }
a { color: inherit; }
img { display: block; width: 100%; }
button, input, textarea, select { font: inherit; }
button { color: inherit; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }
.svg-defs { position: absolute; width: 0; height: 0; overflow: hidden; }
.honeypot { position: absolute!important; left: -9999px!important; }

.site-header {
  height: 82px; padding: 0 clamp(24px, 5vw, 76px); display: flex; align-items: center; gap: 54px;
  position: fixed; z-index: 50; inset: 0 0 auto; transition: .25s ease; color: white;
}
.site-header.scrolled { height: 70px; background: rgba(12,40,34,.96); box-shadow: 0 6px 30px rgba(0,0,0,.12); backdrop-filter: blur(12px); }
.brand { display: inline-flex; align-items: center; gap: 11px; font: 800 20px/1 var(--font-display); letter-spacing: -.8px; text-decoration: none; white-space: nowrap; }
.brand > span:last-child > span { color: var(--lime); }
.brand-mark { display: inline-flex; width: 27px; height: 34px; gap: 3px; align-items: flex-end; transform: skew(-12deg); }
.brand-mark i { width: 7px; display: block; background: var(--lime); border-radius: 1px; }
.brand-mark i:nth-child(1) { height: 18px; }.brand-mark i:nth-child(2) { height: 26px; }.brand-mark i:nth-child(3) { height: 34px; }
.main-nav { display: flex; gap: clamp(24px, 3vw, 45px); margin: auto; }
.main-nav a { color: rgba(255,255,255,.84); text-decoration: none; font-size: 14px; font-weight: 600; }
.main-nav a:hover { color: var(--lime); }
.header-call { display: flex; align-items: center; gap: 10px; text-decoration: none; font-weight: 700; font-size: 14px; }
.header-call svg { width: 18px; height: 18px; fill: var(--lime); }
.menu-button { display: none; background: none; border: 0; margin-left: auto; padding: 8px; }
.menu-button > span:not(.sr-only) { display: block; width: 24px; height: 2px; margin: 5px; background: white; }

.hero { min-height: 760px; height: min(880px, 100vh); position: relative; display: grid; grid-template-columns: 53% 47%; color: white; background: var(--deep); overflow: hidden; }
.hero-grid-lines { position: absolute; inset: 0; opacity: .05; background-image: linear-gradient(rgba(255,255,255,.7) 1px, transparent 1px),linear-gradient(90deg,rgba(255,255,255,.7) 1px,transparent 1px); background-size: 90px 90px; }
.hero-content { position: relative; z-index: 2; align-self: center; padding: 110px 5vw 80px max(6vw, 70px); }
.eyebrow { margin: 0 0 26px; text-transform: uppercase; letter-spacing: 2.4px; font-size: 11px; font-weight: 700; color: var(--forest); }
.eyebrow.light { color: var(--lime); }
.eyebrow span { display: inline-block; width: 24px; height: 1px; margin: 0 10px 4px 0; background: currentColor; }
.hero h1 { max-width: 760px; margin: 0; font: 700 clamp(50px, 6vw, 92px)/.98 var(--font-display); letter-spacing: -5.2px; }
.hero-lead { max-width: 630px; margin: 30px 0 0; color: rgba(255,255,255,.73); font-size: clamp(16px, 1.3vw, 19px); line-height: 1.65; }
.hero-actions { margin-top: 42px; display: flex; align-items: center; gap: 35px; }
.button { display: inline-flex; justify-content: center; align-items: center; gap: 28px; padding: 15px 21px; border: 0; text-decoration: none; font-weight: 700; font-size: 14px; cursor: pointer; transition: .2s; }
.button.primary { background: var(--lime); color: var(--deep); }
.button.primary:hover,.button.lime:hover { background: white; transform: translateY(-2px); }
.button.lime { background: var(--lime); color: var(--deep); }
.button.dark { background: var(--deep); color: white; }
.button.outline { background: transparent; border: 1px solid var(--line); }
.text-link { text-decoration: none; font-size: 14px; font-weight: 600; }
.text-link.light { color: white; }.text-link span { color: var(--lime); margin-left: 12px; }
.hero-art { position: relative; overflow: hidden; background: linear-gradient(155deg,#48675e 0%,#294a42 58%,#183b33 100%); }
.hero-art:before { content:""; position:absolute; inset:0; opacity:.16; background: radial-gradient(circle at 20% 30%,white 0 1px,transparent 2px); background-size: 7px 7px; mix-blend-mode: overlay; }
.sun { position:absolute; width:290px; height:290px; border-radius:50%; background:#d6ef83; opacity:.4; right:-60px; top:90px; filter:blur(1px); }
.ground-cut { position:absolute; inset:auto 0 0; height:34%; background:#182d28; clip-path:polygon(0 20%,100% 0,100% 100%,0 100%); overflow:hidden; }
.ground-cut span { position:absolute; left:-10%; width:125%; height:20%; border-top:1px solid rgba(200,238,88,.28); transform:rotate(-5deg); }
.ground-cut span:nth-child(1){top:35%}.ground-cut span:nth-child(2){top:50%}.ground-cut span:nth-child(3){top:65%}.ground-cut span:nth-child(4){top:80%}
.bore { position:absolute; top:5%; left:43%; height:100%; width:4px; background:var(--lime); box-shadow:0 0 14px var(--lime); }
.rig { position:absolute; z-index:3; width:420px; height:430px; bottom:20%; left:5%; filter:drop-shadow(20px 20px 22px rgba(0,0,0,.25)); }
.rig-body { position:absolute; width:270px; height:105px; bottom:25px; left:50px; background:#d77743; clip-path:polygon(3% 35%,65% 10%,90% 28%,100% 100%,0 100%); }
.rig-mast { position:absolute; left:200px; bottom:90px; height:330px; width:34px; background:linear-gradient(90deg,#e5e1cc 0 30%,#6f7d76 31% 50%,#eee9d3 51% 100%); transform:rotate(-6deg); transform-origin:bottom; }
.rig-mast:after { content:""; position:absolute; inset:10px 9px; border-left:2px dashed #5b675f; }
.rig-arm { position:absolute; left:58px; bottom:120px; width:165px; height:18px; background:#c1c8bc; transform:rotate(-15deg); }
.rig-wheel { position:absolute; z-index:2; bottom:0; width:72px; height:72px; border:15px solid #17231f; background:#737e76; border-radius:50%; box-shadow:inset 0 0 0 5px #263832; }
.rig-wheel.one { left:66px; }.rig-wheel.two { left:260px; }
.hero-stat { position:absolute; z-index:4; right:5vw; bottom:80px; display:flex; gap:13px; align-items:center; }
.hero-stat strong { font:700 44px/1 var(--font-display); color:var(--lime); letter-spacing:-3px; }
.hero-stat span { font-size:11px; line-height:1.3; text-transform:uppercase; letter-spacing:1px; color:rgba(255,255,255,.75); }
.hero-scroll { position:absolute; z-index:4; bottom:38px; left:max(6vw,70px); color:rgba(255,255,255,.55); font-size:10px; text-transform:uppercase; letter-spacing:2px; text-decoration:none; display:flex; align-items:center; gap:14px; }
.hero-scroll i { display:block; width:50px; height:1px; background:rgba(255,255,255,.35); }

.trust-bar { min-height:128px; padding:28px 7vw; display:flex; align-items:center; justify-content:space-between; background:#fff; }
.trust-bar div { display:grid; gap:2px; }.trust-bar strong { font:700 16px var(--font-display); }.trust-bar span { color:var(--muted); font-size:12px; }
.trust-bar > i { width:1px; height:38px; background:var(--line); }
.section { padding:120px max(6vw,60px); }
.section-heading { max-width:1320px; margin:0 auto 68px; display:grid; grid-template-columns:1.15fr .85fr; align-items:end; gap:80px; }
.section-heading h2,.about-copy h2,.projects h2,.contact h2 { margin:0; font:700 clamp(42px,5vw,68px)/1.03 var(--font-display); letter-spacing:-3.5px; }
.section-heading > p { max-width:470px; color:var(--muted); line-height:1.75; margin:0 0 5px; }
.service-grid { max-width:1320px; margin:auto; display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid var(--line); border-left:1px solid var(--line); }
.service-card { min-height:345px; padding:27px; position:relative; display:flex; flex-direction:column; border-right:1px solid var(--line); border-bottom:1px solid var(--line); transition:.25s; }
.service-card:hover,.service-card.featured { background:var(--deep); color:white; transform:translateY(-4px); box-shadow:0 20px 50px rgba(12,40,34,.12); }
.service-number { position:absolute; right:20px; top:18px; font-size:10px; color:#9aa69f; letter-spacing:1px; }
.service-icon { width:52px; height:52px; margin:18px 0 34px; color:var(--forest); }
.service-icon svg { width:100%; height:100%; fill:none; stroke:currentColor; stroke-width:1.4; stroke-linecap:round; stroke-linejoin:round; }
.service-card:hover .service-icon,.service-card.featured .service-icon { color:var(--lime); }
.service-card h3 { margin:0 0 14px; font:700 20px var(--font-display); }
.service-card p { margin:0 0 22px; color:var(--muted); font-size:13px; line-height:1.65; }
.service-card:hover p,.service-card.featured p { color:rgba(255,255,255,.65); }
.service-card a { margin-top:auto; text-decoration:none; text-transform:uppercase; letter-spacing:1.2px; font-size:10px; font-weight:700; opacity:0; transform:translateY(5px); transition:.2s; }
.service-card:hover a,.service-card.featured a { opacity:1; transform:none; }.service-card a span { color:var(--lime); margin-left:8px; }

.about { display:grid; grid-template-columns:1fr 1fr; min-height:760px; background:var(--deep); color:white; }
.about-visual { position:relative; min-height:680px; background:#46635a; overflow:hidden; }
.about-visual img { width:100%; height:100%; object-fit:cover; filter:saturate(.75) contrast(1.05); }
.about-visual:after { content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(12,40,34,.1),rgba(12,40,34,.45)); }
.about-placeholder { height:100%; display:grid; place-items:center; background:radial-gradient(circle at 40% 30%,#668078,#29483f 70%); }
.brand-mark.large { transform:scale(5) skew(-12deg); opacity:.3; }
.since { position:absolute; z-index:2; right:0; bottom:0; width:160px; height:125px; padding:22px; background:var(--lime); color:var(--deep); }
.since span { display:block; font-size:11px; text-transform:uppercase; letter-spacing:2px; }.since strong { font:700 41px var(--font-display); letter-spacing:-2px; }
.about-copy { display:flex; flex-direction:column; justify-content:center; padding:90px clamp(50px,7vw,115px); }
.about-copy h2 { max-width:570px; }
.rich-text { margin:28px 0 15px; color:rgba(255,255,255,.7); font-size:15px; line-height:1.75; }.rich-text p { margin:0 0 12px; }
.about-facts { display:grid; grid-template-columns:repeat(3,1fr); margin:25px 0; padding:25px 0; border-block:1px solid rgba(255,255,255,.15); }
.about-facts div+div { padding-left:22px; border-left:1px solid rgba(255,255,255,.15); }
.about-facts dt { font:700 24px var(--font-display); color:var(--lime); }.about-facts dd { margin:3px 0 0; font-size:10px; text-transform:uppercase; letter-spacing:1.2px; color:rgba(255,255,255,.55); }
.about details { border-bottom:1px solid rgba(255,255,255,.15); }.about summary { cursor:pointer; list-style:none; padding:16px 0; font-weight:700; font-size:13px; }.about summary span { float:right; color:var(--lime); font-size:20px; }.about details div { color:rgba(255,255,255,.65); font-size:14px; }
.process { background:#fff; }
.section-heading.compact { grid-template-columns:1fr; }
.process-list { max-width:1320px; padding:0; margin:auto; list-style:none; display:grid; grid-template-columns:repeat(4,1fr); }
.process-list li { position:relative; padding:0 34px; border-left:1px solid var(--line); }
.process-list li:first-child { padding-left:0; border:0; }.process-list li:before { content:""; position:absolute; top:17px; left:0; right:0; height:1px; background:var(--line); }
.process-list span { position:relative; z-index:1; display:grid; place-items:center; width:35px; height:35px; margin-bottom:45px; border-radius:50%; background:var(--deep); color:var(--lime); font-size:9px; }
.process-list li:first-child span { margin-left:0; }.process-list h3 { font:700 17px var(--font-display); }.process-list p { color:var(--muted); font-size:13px; line-height:1.7; }

.projects { padding:120px max(6vw,60px); background:#173b33; color:white; }
.projects-heading { max-width:1320px; margin:0 auto 60px; }
.project-grid { max-width:1320px; margin:auto; display:grid; grid-template-columns:1.4fr .8fr .8fr; grid-template-rows:240px 240px; gap:12px; }
.project-grid figure { margin:0; overflow:hidden; position:relative; background:#315249; }.project-grid img { height:100%; object-fit:cover; transition:.6s; }.project-grid figure:hover img { transform:scale(1.04); }
.project-1 { grid-row:1/3; }.project-4 { grid-column:2/3; }.project-5 { grid-column:3/4; }
.project-grid figcaption { position:absolute; bottom:0; inset-inline:0; padding:30px 16px 14px; background:linear-gradient(transparent,rgba(0,0,0,.55)); font-size:12px; }

.contact { display:grid; grid-template-columns:1fr 1fr; background:#e7653d; }
.contact-intro { padding:110px max(6vw,70px); color:white; }.contact-intro .eyebrow { color:#3c261e; }.contact-intro > p:not(.eyebrow) { max-width:490px; color:rgba(255,255,255,.78); }
.direct-contact { margin-top:50px; display:grid; gap:17px; }.direct-contact a { text-decoration:none; display:grid; }.direct-contact small { text-transform:uppercase; letter-spacing:1.5px; color:#3c261e; font-size:9px; font-weight:700; }.direct-contact strong { font:700 20px var(--font-display); }
.contact-form { padding:85px clamp(45px,7vw,105px); background:#fff; }
.contact-form label,.editor-form label,.login-card label { display:grid; gap:7px; margin-bottom:19px; font-size:10px; text-transform:uppercase; letter-spacing:1.1px; font-weight:700; }
input,textarea,select { width:100%; padding:12px 2px; border:0; border-bottom:1px solid #bfc8c2; background:transparent; border-radius:0; color:var(--ink); outline:none; }
input:focus,textarea:focus,select:focus { border-color:var(--forest); box-shadow:0 1px var(--forest); }
textarea { resize:vertical; }
.form-row,.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:28px; }.form-grid.thirds { grid-template-columns:repeat(3,1fr); }
.contact-form .button { width:100%; margin-top:14px; }.form-note { text-align:center; color:#88938f; font-size:10px; }

footer { padding:75px max(6vw,70px) 25px; background:#0a211c; color:white; }
.footer-top { display:grid; grid-template-columns:1fr 1fr auto; gap:40px; align-items:start; padding-bottom:45px; border-bottom:1px solid rgba(255,255,255,.13); }
.footer-top p { max-width:400px; margin:0; color:rgba(255,255,255,.55); font-size:14px; }.to-top { display:grid; place-items:center; width:42px; height:42px; border:1px solid rgba(255,255,255,.25); text-decoration:none; }
.footer-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:45px; padding:50px 0; }.footer-grid h3 { color:var(--lime); text-transform:uppercase; letter-spacing:1.5px; font-size:9px; }.footer-grid p { color:rgba(255,255,255,.58); font-size:12px; line-height:1.8; }.footer-grid a { text-decoration:none; }
.partners { display:flex; gap:15px 25px; flex-wrap:wrap; padding:20px 0; border-top:1px solid rgba(255,255,255,.13); color:rgba(255,255,255,.42); font-size:10px; }.partners span { color:var(--lime); text-transform:uppercase; letter-spacing:1px; }.partners a { text-decoration:none; }
.footer-bottom { display:flex; justify-content:space-between; padding-top:25px; border-top:1px solid rgba(255,255,255,.13); color:rgba(255,255,255,.36); font-size:10px; }

.flash-stack { position:fixed; z-index:100; top:85px; right:20px; width:min(390px,calc(100% - 40px)); }.flash { margin-bottom:8px; padding:13px 17px; background:white; border-left:4px solid var(--forest); box-shadow:0 8px 30px rgba(0,0,0,.18); font-size:13px; }.flash.success { border-color:#47a45a; }.flash.danger { border-color:#d54c3d; }

/* CMS */
.admin-body { background:#eef0eb; }
.admin-sidebar { position:fixed; inset:0 auto 0 0; width:245px; padding:28px 24px; display:flex; flex-direction:column; color:white; background:var(--deep); }
.admin-sidebar > p { color:rgba(255,255,255,.42); margin:6px 0 35px 38px; font-size:10px; text-transform:uppercase; letter-spacing:1.3px; }
.admin-sidebar nav { display:grid; gap:5px; }.admin-sidebar a { padding:10px 12px; color:rgba(255,255,255,.7); text-decoration:none; font-size:13px; border-radius:4px; }.admin-sidebar nav a:hover { background:rgba(255,255,255,.08); color:white; }.admin-sidebar b { float:right; display:grid; place-items:center; min-width:20px; height:20px; border-radius:10px; color:var(--deep); background:var(--lime); font-size:10px; }
.admin-sidebar > div { margin-top:auto; display:grid; }
.admin-main { margin-left:245px; padding:45px clamp(28px,5vw,80px) 100px; }
.admin-main > header { max-width:1100px; margin:0 auto 35px; display:flex; align-items:center; justify-content:space-between; }.admin-main > header p { margin:0; color:var(--orange); font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:2px; }.admin-main > header h1 { margin:3px 0 0; font:700 27px var(--font-display); }
.admin-panel { max-width:1100px; margin:0 auto 22px; background:white; padding:35px; box-shadow:0 3px 15px rgba(18,40,35,.04); }
.panel-heading { display:flex; align-items:start; justify-content:space-between; gap:30px; padding-bottom:23px; margin-bottom:25px; border-bottom:1px solid #e5e8e3; }.panel-heading span { color:var(--orange); font-size:9px; text-transform:uppercase; letter-spacing:1.5px; font-weight:700; }.panel-heading h2 { margin:4px 0 0; font:700 20px var(--font-display); }.panel-heading > p { max-width:350px; margin:0; color:var(--muted); font-size:12px; }
.editor-form input,.editor-form textarea,.editor-form select,.login-card input { padding:10px 12px; border:1px solid #ced5d0; background:#fafbf9; }.editor-form label { margin-bottom:16px; }
.editor-form .button { margin-top:8px; }
.item-list { display:grid; gap:7px; }.item-editor { border:1px solid #e0e4df; }.item-editor summary { list-style:none; padding:15px 17px; display:grid; grid-template-columns:25px 1fr auto; align-items:center; cursor:pointer; }.item-editor summary::-webkit-details-marker { display:none; }.item-editor summary strong { font-size:13px; }.item-editor summary > span:last-child { color:var(--muted); font-size:11px; }.drag { color:#adb5af; }.compact-form { padding:20px; border-top:1px solid #e0e4df; background:#f8f9f6; }.new-item { display:none; border:1px dashed var(--forest); }.new-item[open] { display:block; }.new-item summary { grid-template-columns:1fr auto; }
.check { align-content:center; display:flex!important; flex-direction:row; align-items:center; text-transform:none!important; font-size:12px!important; }.check input { width:auto; }
.form-actions { display:flex; align-items:center; gap:15px; }.danger-link,.text-button { border:0; background:transparent; cursor:pointer; color:#b84939; text-decoration:underline; font-size:11px; }.inquiry { border-bottom:1px solid #e0e4df; }.inquiry summary { list-style:none; display:grid; grid-template-columns:12px 1fr 1fr auto; gap:15px; align-items:center; padding:15px 5px; cursor:pointer; font-size:12px; }.inquiry summary i { width:7px; height:7px; border-radius:50%; background:var(--orange); }.inquiry.read summary i { background:#c7cec9; }.inquiry summary span,.inquiry time { color:var(--muted); }.inquiry > div { padding:0 35px 18px; font-size:13px; }.empty { color:var(--muted); font-size:13px; }

.login-body { min-height:100vh; background:var(--deep); }.login-shell { min-height:100vh; padding:35px max(5vw,40px); display:grid; grid-template-rows:auto 1fr; }.login-card { place-self:center; width:min(470px,100%); padding:48px; background:white; box-shadow:0 30px 80px rgba(0,0,0,.2); }.login-card h1 { margin:0; font:700 36px var(--font-display); letter-spacing:-2px; }.login-card > p:not(.eyebrow) { color:var(--muted); margin-bottom:30px; }.login-card .button { width:100%; margin-top:12px; }

@media (max-width: 1000px) {
  .site-header { gap:25px; }.main-nav { gap:20px; }.header-call span { display:none; }
  .hero { grid-template-columns:1fr 42%; }.hero-content { padding-left:45px; }.hero h1 { font-size:62px; }.rig { left:-90px; transform:scale(.8); }
  .service-grid { grid-template-columns:repeat(2,1fr); }.about-copy { padding:70px 45px; }.about-facts { grid-template-columns:1fr; gap:12px; }.about-facts div+div { padding:12px 0 0; border-left:0; border-top:1px solid rgba(255,255,255,.15); }
  .process-list { grid-template-columns:1fr 1fr; gap:45px 0; }.project-grid { grid-template-columns:1fr 1fr; }.project-5 { display:none; }.contact-intro,.contact-form { padding:75px 45px; }
  .admin-sidebar { width:205px; }.admin-main { margin-left:205px; padding-inline:25px; }
}

@media (max-width: 720px) {
  html { scroll-padding-top:68px; }.site-header { height:68px; padding:0 20px; }.menu-button { display:block; }.header-call { display:none; }
  .main-nav { position:absolute; top:68px; left:0; right:0; padding:25px; display:none; flex-direction:column; background:var(--deep); }.main-nav.open { display:flex; }
  .hero { height:auto; min-height:780px; display:block; }.hero-content { padding:130px 24px 65px; }.hero h1 { font-size:clamp(44px,14vw,64px); letter-spacing:-3.4px; }.hero-actions { align-items:flex-start; flex-direction:column; gap:22px; }.hero-art { height:330px; }.rig { left:5%; bottom:10%; transform:scale(.62); transform-origin:bottom left; }.hero-stat { bottom:25px; }.hero-scroll { display:none; }
  .trust-bar { display:grid; grid-template-columns:1fr 1fr; gap:25px; padding:30px 24px; }.trust-bar > i { display:none; }
  .section { padding:80px 22px; }.section-heading { display:block; margin-bottom:45px; }.section-heading h2,.about-copy h2,.projects h2,.contact h2 { font-size:42px; letter-spacing:-2.5px; }.section-heading > p { margin-top:25px; }
  .service-grid { grid-template-columns:1fr; }.service-card { min-height:300px; }.service-card a { opacity:1; }
  .about { grid-template-columns:1fr; }.about-visual { min-height:420px; }.about-copy { padding:70px 24px; }
  .process-list { grid-template-columns:1fr; }.process-list li { padding:0 0 0 55px; border:0; }.process-list li:before { width:1px; height:100%; left:17px; }.process-list span { position:absolute; left:0; margin:0; }
  .projects { padding:80px 22px; }.project-grid { grid-template-columns:1fr; grid-template-rows:360px 220px 220px; }.project-1 { grid-row:auto; }.project-4,.project-5 { display:none; }
  .contact { grid-template-columns:1fr; }.contact-intro,.contact-form { padding:70px 24px; }.form-row,.form-grid,.form-grid.thirds { grid-template-columns:1fr; gap:0; }
  footer { padding:60px 24px 25px; }.footer-top { grid-template-columns:1fr auto; }.footer-top p { grid-row:2; }.footer-grid { grid-template-columns:1fr 1fr; }.footer-bottom { gap:15px; flex-direction:column; }
  .admin-sidebar { position:static; width:auto; padding:20px; }.admin-sidebar > p,.admin-sidebar nav { display:none; }.admin-sidebar > div { position:absolute; top:20px; right:12px; display:flex; }.admin-main { margin:0; padding:30px 12px 70px; }.admin-main > header .button { display:none; }.admin-panel { padding:22px 16px; }.panel-heading { flex-direction:column; }.inquiry summary { grid-template-columns:12px 1fr auto; }.inquiry summary span { display:none; }
  .login-shell { padding:24px; }.login-card { padding:32px 24px; }
}

@media (prefers-reduced-motion: reduce) { html { scroll-behavior:auto; } *,*:before,*:after { transition-duration:.01ms!important; animation-duration:.01ms!important; } }

/* -------------------------------------------------------------------------- */
/* Public site – light industrial identity                                     */
/* -------------------------------------------------------------------------- */
.public-v2 {
  --v2-yellow: #fbb900;
  --v2-ink: #171615;
  --v2-grey: #626261;
  --v2-paper: #f7f6f2;
  --v2-mineral: #e8e9e5;
  --v2-silver: #d9ddda;
  --v2-white: #fff;
  background: var(--v2-paper);
  color: var(--v2-ink);
  font-family: "Manrope", sans-serif;
}
.public-v2 main { overflow: hidden; }
.v2-header {
  position: absolute;
  z-index: 30;
  inset: 0 0 auto;
  height: 104px;
  padding: 0 clamp(28px, 5vw, 78px);
  display: grid;
  grid-template-columns: minmax(230px, 330px) 1fr auto;
  align-items: center;
  gap: 38px;
  background: rgba(255,255,255,.9);
  border-bottom: 1px solid rgba(23,22,21,.1);
  backdrop-filter: blur(18px);
  transition: height .25s, box-shadow .25s, background .25s;
}
.v2-header.scrolled {
  position: fixed;
  height: 78px;
  background: rgba(255,255,255,.96);
  box-shadow: 0 12px 45px rgba(23,22,21,.08);
}
.v2-logo { width: min(100%, 310px); height: 78px; display: flex; align-items: center; overflow: hidden; }
.v2-logo img { width: 100%; height: auto; margin-top: 1px; }
.v2-nav { justify-self: end; display: flex; align-items: center; gap: clamp(24px,3vw,52px); }
.v2-nav a { text-decoration: none; font-size: 14px; font-weight: 600; color: var(--v2-ink); }
.v2-nav a:after { content:""; display:block; width:0; height:2px; margin-top:5px; background:var(--v2-yellow); transition:.2s; }
.v2-nav a:hover:after { width:100%; }
.v2-header-cta { display: inline-flex; align-items: center; gap: 20px; padding: 13px 18px; background: var(--v2-ink); color: white; text-decoration: none; font-size: 12px; font-weight: 700; }
.v2-header-cta span { color: var(--v2-yellow); }
.v2-menu-button { justify-self: end; }

.v2-hero {
  position: relative;
  min-height: 750px;
  padding-top: 104px;
  display: grid;
  grid-template-columns: 42% 58%;
  background: var(--v2-paper);
}
.v2-hero:before {
  content:"";
  position:absolute;
  left:-8vw;
  bottom:-16vw;
  width:30vw;
  height:30vw;
  border:1px solid rgba(98,98,97,.18);
  border-radius:50%;
  box-shadow:0 0 0 8vw rgba(255,255,255,.28);
}
.v2-hero-copy {
  position: relative;
  z-index: 2;
  align-self: center;
  padding: 80px clamp(38px, 6.4vw, 106px);
}
.v2-kicker {
  margin: 0 0 25px;
  font: 400 11px/1.2 "Bungee", sans-serif;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--v2-grey);
}
.v2-kicker.yellow { color: #a87900; }
.v2-hero h1 {
  max-width: 640px;
  margin: 0;
  font: 500 clamp(51px, 5.1vw, 78px)/1.04 "Manrope", sans-serif;
  letter-spacing: -4.8px;
}
.v2-lead {
  max-width: 530px;
  margin: 30px 0 0;
  font-size: clamp(16px,1.25vw,19px);
  line-height: 1.6;
  color: #474744;
}
.v2-actions { display:flex; align-items:center; gap:35px; margin-top:42px; }
.v2-button {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:38px;
  min-height:54px;
  padding:0 25px;
  border:0;
  text-decoration:none;
  font-size:13px;
  font-weight:700;
  cursor:pointer;
  transition:transform .2s,box-shadow .2s,background .2s;
}
.v2-button:hover { transform:translateY(-2px); box-shadow:0 12px 28px rgba(23,22,21,.12); }
.v2-button-yellow { background:var(--v2-yellow); color:var(--v2-ink); }
.v2-button-yellow:hover { background:#ffc928; }
.v2-text-link { color:var(--v2-ink); text-decoration:none; font-size:13px; font-weight:600; border-bottom:2px solid var(--v2-yellow); padding:10px 0 6px; }
.v2-text-link span { margin-left:12px; }
.v2-hero-media {
  position:relative;
  min-width:0;
  overflow:hidden;
  clip-path:polygon(8% 0,100% 0,100% 100%,0 100%,0 17%);
  background:var(--v2-silver);
}
.v2-hero-media > img:first-child { width:100%; height:100%; object-fit:cover; object-position:center; }
.v2-hero-media:after { content:""; position:absolute; inset:0; box-shadow:inset 0 0 90px rgba(23,22,21,.12); pointer-events:none; }
.v2-avatar { position:absolute; z-index:2; right:4%; bottom:6%; width:118px; height:118px; object-fit:contain; filter:drop-shadow(0 12px 18px rgba(0,0,0,.17)); }
.v2-photo-label { position:absolute; z-index:2; top:34px; right:34px; padding:9px 12px; background:rgba(255,255,255,.86); backdrop-filter:blur(10px); font-size:9px; font-weight:700; letter-spacing:1.2px; text-transform:uppercase; }
.v2-pixels { position:absolute; z-index:2; display:grid; grid-template-columns:repeat(3,8px); gap:9px; opacity:.55; }
.v2-pixels i { width:8px; height:8px; background:var(--v2-grey); }
.v2-pixels i:nth-child(3n),.v2-pixels i:nth-child(7) { background:var(--v2-yellow); }
.v2-pixels i:nth-child(2),.v2-pixels i:nth-child(6) { opacity:0; }
.v2-pixels-hero { left:22px; top:170px; transform:rotate(5deg); }

.v2-trust {
  position:relative;
  z-index:4;
  width:min(92%,1420px);
  min-height:104px;
  margin:-20px auto 0;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  background:white;
  border:1px solid rgba(23,22,21,.07);
  border-radius:20px;
  box-shadow:0 18px 50px rgba(23,22,21,.08);
}
.v2-trust > div { display:flex; align-items:center; justify-content:center; gap:20px; padding:22px 35px; }
.v2-trust > div+div { border-left:1px solid var(--v2-silver); }
.v2-trust-icon { display:grid; place-items:center; flex:0 0 42px; width:42px; height:42px; border-radius:50%; background:#f1f2ef; font-size:14px; font-weight:800; }
.v2-trust p { margin:0; display:grid; gap:3px; }
.v2-trust strong { font-size:12px; text-transform:uppercase; letter-spacing:.7px; }
.v2-trust small { color:#82827f; font-size:10px; }

.v2-services { padding:130px max(5vw,55px); background:linear-gradient(110deg,var(--v2-paper) 0 38%,var(--v2-mineral) 38% 100%); }
.v2-section-intro { max-width:1380px; margin:0 auto 65px; display:grid; grid-template-columns:1.2fr .8fr; gap:90px; align-items:end; }
.v2-section-intro h2,.v2-about h2,.v2-projects h2,.v2-contact h2 {
  margin:0;
  font:500 clamp(42px,4.5vw,68px)/1.08 "Manrope",sans-serif;
  letter-spacing:-3.6px;
}
.v2-section-intro > p { max-width:480px; margin:0 0 5px; color:#686864; line-height:1.75; font-size:14px; }
.v2-service-grid { max-width:1380px; margin:auto; display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.v2-service-card {
  position:relative;
  min-height:335px;
  padding:30px;
  display:flex;
  flex-direction:column;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(23,22,21,.06);
  border-radius:18px;
  box-shadow:0 12px 35px rgba(23,22,21,.045);
  transition:transform .25s,box-shadow .25s;
}
.v2-service-card:nth-child(2),.v2-service-card:nth-child(5),.v2-service-card:nth-child(8) { transform:translateY(22px); }
.v2-service-card:hover { transform:translateY(-6px); box-shadow:0 24px 55px rgba(23,22,21,.1); }
.v2-service-card:nth-child(2):hover,.v2-service-card:nth-child(5):hover,.v2-service-card:nth-child(8):hover { transform:translateY(16px); }
.v2-service-featured { background:var(--v2-ink); color:white; }
.v2-card-number { position:absolute; right:24px; top:21px; color:#999994; font-size:9px; letter-spacing:1px; }
.v2-service-icon { width:60px; height:60px; margin:15px 0 35px; color:var(--v2-ink); }
.v2-service-icon svg { width:100%; height:100%; fill:none; stroke:currentColor; stroke-width:1.25; stroke-linecap:round; stroke-linejoin:round; }
.v2-service-featured .v2-service-icon { color:var(--v2-yellow); }
.v2-service-card h3 { margin:0 0 13px; font-size:19px; letter-spacing:-.5px; }
.v2-service-card p { margin:0 0 20px; color:#74746f; font-size:12px; line-height:1.7; }
.v2-service-featured p { color:rgba(255,255,255,.58); }
.v2-service-card a { margin-top:auto; color:inherit; text-decoration:none; font-size:11px; font-weight:700; }
.v2-service-card a span { float:right; color:var(--v2-yellow); font-size:18px; }

.v2-about { min-height:780px; display:grid; grid-template-columns:1.05fr .95fr; background:white; }
.v2-about-media { position:relative; min-height:680px; overflow:hidden; background:var(--v2-silver); }
.v2-about-media img { height:100%; object-fit:cover; }
.v2-about-media:before { content:""; position:absolute; z-index:1; inset:0; background:linear-gradient(135deg,transparent 55%,rgba(23,22,21,.25)); }
.v2-year-card { position:absolute; z-index:2; right:0; bottom:0; width:190px; padding:26px 28px; display:grid; background:var(--v2-yellow); }
.v2-year-card small,.v2-year-card span { font-size:9px; text-transform:uppercase; letter-spacing:1.4px; font-weight:700; }
.v2-year-card strong { font-size:46px; line-height:1.1; letter-spacing:-3px; }
.v2-about-copy { align-self:center; padding:90px clamp(48px,7vw,115px); }
.v2-about-copy .v2-rich-text { margin:28px 0; color:#656561; font-size:14px; line-height:1.8; }
.v2-facts { margin:35px 0 20px; padding:28px 0; display:grid; grid-template-columns:repeat(3,1fr); border-block:1px solid var(--v2-silver); }
.v2-facts div { display:grid; gap:4px; }
.v2-facts div+div { padding-left:25px; border-left:1px solid var(--v2-silver); }
.v2-facts strong { font-size:22px; }.v2-facts span { color:#777773; text-transform:uppercase; font-size:8px; letter-spacing:1px; }
.v2-history { border-bottom:1px solid var(--v2-silver); }
.v2-history summary { padding:17px 0; cursor:pointer; list-style:none; font-size:12px; font-weight:700; }
.v2-history summary span { float:right; color:#ae8000; font-size:20px; }.v2-history > div { padding-bottom:15px; color:#686864; font-size:13px; }

.v2-process { padding:125px max(5vw,55px); background:var(--v2-paper); }
.v2-process-list { max-width:1380px; margin:auto; padding:0; display:grid; grid-template-columns:repeat(4,1fr); list-style:none; border-top:1px solid #cfd2cd; }
.v2-process-list li { position:relative; padding:38px 34px 5px; }
.v2-process-list li+li { border-left:1px solid #cfd2cd; }
.v2-process-list > li > span { position:absolute; top:-17px; left:30px; display:grid; place-items:center; width:34px; height:34px; border-radius:50%; background:var(--v2-yellow); font-size:9px; font-weight:800; }
.v2-process-list h3 { margin:10px 0 13px; font-size:16px; }.v2-process-list p { color:#70706c; font-size:12px; line-height:1.7; }

.v2-projects { padding:120px max(5vw,55px); background:var(--v2-mineral); }
.v2-project-heading { max-width:1380px; margin:0 auto 55px; display:grid; grid-template-columns:1fr .7fr; gap:80px; align-items:end; }
.v2-project-heading > p { max-width:420px; color:#666662; font-size:14px; line-height:1.75; }
.v2-project-grid { max-width:1380px; height:620px; margin:auto; display:grid; grid-template-columns:1.3fr .7fr .7fr; grid-template-rows:1fr 1fr; gap:14px; }
.v2-project-grid figure { position:relative; margin:0; overflow:hidden; border-radius:14px; background:#cacdc8; }
.v2-project-open { width:100%; height:100%; padding:0; display:block; border:0; background:transparent; cursor:zoom-in; }
.v2-project-open:focus-visible { outline:4px solid var(--v2-yellow); outline-offset:-4px; }
.v2-project-grid img { width:100%; height:100%; object-fit:cover; transition:transform .6s; }.v2-project-grid figure:hover img { transform:scale(1.04); }
.v2-project-1 { grid-row:1/3; }.v2-project-grid figcaption { position:absolute; inset:auto 0 0; padding:45px 18px 17px; color:white; background:linear-gradient(transparent,rgba(0,0,0,.68)); font-size:11px; }
.v2-project-grid figcaption span { margin-right:12px; color:var(--v2-yellow); font-weight:800; }
.v2-more-projects { max-width:1380px; margin:70px auto 0; }
.v2-rail-heading { margin-bottom:24px; display:flex; align-items:end; justify-content:space-between; gap:30px; }
.v2-rail-heading .v2-kicker { margin-bottom:8px; }
.v2-rail-heading p:last-child { margin:0; color:#757570; font-size:11px; }
.v2-rail-controls { display:flex; gap:9px; }
.v2-rail-controls button {
  width:48px;
  height:48px;
  border:0;
  border-radius:50%;
  color:var(--v2-ink);
  background:var(--v2-yellow);
  font-size:21px;
  cursor:pointer;
  transition:opacity .2s,transform .2s,background .2s;
}
.v2-rail-controls button:hover:not(:disabled) { transform:translateY(-2px); background:#ffc928; }
.v2-rail-controls button:disabled { opacity:.3; cursor:default; }
.v2-project-rail {
  margin-inline:calc(max(5vw,55px) * -1);
  padding:0 max(5vw,55px) 18px;
  display:flex;
  gap:16px;
  overflow-x:auto;
  overscroll-behavior-inline:contain;
  scroll-snap-type:x mandatory;
  scrollbar-width:thin;
  scrollbar-color:var(--v2-yellow) transparent;
}
.v2-project-rail::-webkit-scrollbar { height:5px; }
.v2-project-rail::-webkit-scrollbar-thumb { background:var(--v2-yellow); border-radius:3px; }
.v2-rail-card {
  position:relative;
  flex:0 0 clamp(280px,31vw,430px);
  aspect-ratio:4/3;
  margin:0;
  overflow:hidden;
  scroll-snap-align:start;
  border-radius:14px;
  background:#c9ccc7;
}
.v2-rail-card img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.v2-rail-card:hover img { transform:scale(1.035); }
.v2-rail-card figcaption { position:absolute; inset:auto 0 0; padding:48px 18px 17px; color:#fff; background:linear-gradient(transparent,rgba(0,0,0,.72)); font-size:11px; pointer-events:none; }
.v2-rail-card figcaption span { margin-right:12px; color:var(--v2-yellow); font-size:15px; font-weight:800; }
.v2-lightbox {
  width:min(1160px,calc(100% - 80px));
  max-width:none;
  height:min(820px,calc(100% - 80px));
  max-height:none;
  padding:0;
  overflow:visible;
  border:0;
  border-radius:16px;
  color:#fff;
  background:#111;
  box-shadow:0 35px 100px rgba(0,0,0,.45);
}
.v2-lightbox::backdrop { background:rgba(9,9,8,.83); backdrop-filter:blur(7px); }
.v2-lightbox figure { width:100%; height:100%; margin:0; display:grid; grid-template-rows:1fr auto; overflow:hidden; border-radius:16px; }
.v2-lightbox figure img { width:100%; height:100%; min-height:0; object-fit:contain; }
.v2-lightbox figcaption { min-height:62px; padding:16px 75px 16px 22px; display:flex; align-items:center; gap:17px; color:#d3d3cf; background:#181817; font-size:12px; }
.v2-lightbox figcaption [data-lightbox-number] { color:var(--v2-yellow); font-size:16px; font-weight:800; }
.v2-lightbox-close,.v2-lightbox-arrow {
  position:absolute;
  z-index:3;
  display:grid;
  place-items:center;
  border:0;
  color:var(--v2-ink);
  background:var(--v2-yellow);
  cursor:pointer;
}
.v2-lightbox-close { top:14px; right:14px; width:42px; height:42px; border-radius:50%; font-size:26px; }
.v2-lightbox-arrow { top:50%; width:48px; height:58px; font-size:22px; transform:translateY(-50%); }
.v2-lightbox-arrow.previous { left:-24px; }.v2-lightbox-arrow.next { right:-24px; }

.v2-contact-banner { margin:0; padding:38px max(5vw,72px); display:grid; grid-template-columns:auto 1fr auto auto; align-items:center; gap:38px; color:white; background:var(--v2-ink); }
.v2-contact-banner h2 { margin:0; font-size:clamp(24px,3vw,42px); font-weight:500; letter-spacing:-2px; }
.v2-contact-banner > a:not(.v2-button) { padding:0 45px; color:white; text-decoration:none; font-size:25px; font-weight:500; border-left:1px solid rgba(255,255,255,.2); }
.v2-contact-icon { display:grid; place-items:center; width:50px; height:50px; border-radius:50%; color:var(--v2-ink); background:var(--v2-yellow); font-size:25px; }
.v2-contact { display:grid; grid-template-columns:.9fr 1.1fr; background:white; }
.v2-contact-copy { padding:110px clamp(45px,7vw,110px); background:var(--v2-paper); }
.v2-contact-copy > p:not(.v2-kicker) { max-width:500px; color:#6d6d68; line-height:1.7; }
.v2-direct { margin-top:45px; display:grid; grid-template-columns:1fr 1fr; gap:25px; }
.v2-direct a,.v2-direct > div { display:grid; align-content:start; color:inherit; text-decoration:none; }
.v2-direct > div { grid-column:1/3; padding-top:22px; border-top:1px solid var(--v2-silver); }
.v2-direct small { color:#898984; text-transform:uppercase; letter-spacing:1.2px; font-size:8px; font-weight:700; }
.v2-direct strong { margin-top:4px; font-size:15px; }.v2-direct span { color:#898984; font-size:11px; }
.v2-contact-form { padding:90px clamp(45px,8vw,130px); }
.v2-contact-form label { display:grid; gap:7px; margin-bottom:19px; color:#555551; font-size:9px; text-transform:uppercase; letter-spacing:1.1px; font-weight:700; }
.v2-contact-form input,.v2-contact-form textarea,.v2-contact-form select { padding:13px 2px; background:transparent; border:0; border-bottom:1px solid #bfc3bd; }
.v2-contact-form .v2-button { width:100%; margin-top:14px; }
.v2-form-note { text-align:center; color:#999994; font-size:9px; }

.v2-footer { padding:55px max(5vw,72px) 25px; background:white; border-top:1px solid var(--v2-silver); }
.v2-footer-main { display:grid; grid-template-columns:300px 1fr auto; align-items:center; gap:60px; padding-bottom:40px; }
.v2-footer-main img { width:280px; height:auto; aspect-ratio:581/189; object-fit:contain; object-position:left center; }.v2-footer-main p { max-width:500px; color:#6d6d68; font-size:13px; }
.v2-footer-main > a { display:grid; place-items:center; width:44px; height:44px; color:white; background:var(--v2-ink); text-decoration:none; }
.v2-footer-details { padding-top:22px; display:flex; justify-content:space-between; gap:30px; border-top:1px solid var(--v2-silver); color:#848480; font-size:9px; }.v2-footer-details a { text-decoration:none; }
.back-to-top {
  position:fixed;
  z-index:24;
  right:24px;
  bottom:24px;
  min-height:52px;
  padding:6px 17px 6px 6px;
  display:flex;
  align-items:center;
  gap:11px;
  border:0;
  border-radius:28px;
  color:white;
  background:rgba(23,22,21,.94);
  box-shadow:0 15px 38px rgba(23,22,21,.22);
  backdrop-filter:blur(10px);
  cursor:pointer;
  opacity:0;
  pointer-events:none;
  transform:translateY(18px);
  transition:opacity .25s,transform .25s,background .2s;
}
.back-to-top.visible { opacity:1; pointer-events:auto; transform:none; }
.back-to-top:hover { background:var(--v2-ink); transform:translateY(-2px); }
.back-to-top span { width:40px; height:40px; display:grid; place-items:center; border-radius:50%; color:var(--v2-ink); background:var(--v2-yellow); font-size:20px; }
.back-to-top strong { font-size:9px; letter-spacing:1.1px; text-transform:uppercase; }
.back-to-top:focus-visible { outline:3px solid var(--v2-yellow); outline-offset:3px; }

/* Public service landing pages */
.service-hero {
  min-height: 720px;
  padding-top: 104px;
  display: grid;
  grid-template-columns: 54% 46%;
  color: white;
  background: var(--v2-ink);
}
.service-hero-copy {
  position: relative;
  padding: 95px clamp(45px,7vw,125px) 85px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
}
.service-hero-copy:after {
  content:"";
  position:absolute;
  right:-130px;
  bottom:-180px;
  width:430px;
  height:430px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:50%;
  box-shadow:0 0 0 95px rgba(255,255,255,.025);
}
.service-breadcrumbs {
  position:relative;
  z-index:1;
  margin-bottom:60px;
  display:flex;
  gap:13px;
  color:rgba(255,255,255,.55);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:1.1px;
}
.service-breadcrumbs a { color:white; text-decoration:none; }
.service-hero .v2-kicker { position:relative; z-index:1; color:var(--v2-yellow); }
.service-hero h1 {
  position:relative;
  z-index:1;
  max-width:760px;
  margin:0;
  font:500 clamp(50px,5.5vw,82px)/1.02 "Manrope",sans-serif;
  letter-spacing:-5px;
}
.service-hero-copy > p:not(.v2-kicker) {
  position:relative;
  z-index:1;
  max-width:680px;
  margin:30px 0 0;
  color:rgba(255,255,255,.7);
  font-size:clamp(16px,1.3vw,20px);
  line-height:1.7;
}
.service-hero .v2-actions { position:relative; z-index:1; }
.service-phone {
  padding:10px 0 6px;
  color:white;
  text-decoration:none;
  font-size:13px;
  font-weight:600;
  border-bottom:2px solid var(--v2-yellow);
}
.service-hero-media { position:relative; min-width:0; overflow:hidden; background:#c8ccc7; }
.service-hero-media:after { content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(23,22,21,.25),transparent 45%); }
.service-hero-media img { width:100%; height:100%; object-fit:cover; }
.service-hero-media > span {
  position:absolute;
  z-index:2;
  right:34px;
  bottom:34px;
  padding:10px 14px;
  color:var(--v2-ink);
  background:var(--v2-yellow);
  font:400 10px "Bungee",sans-serif;
  letter-spacing:1px;
  text-transform:uppercase;
}
.service-intro {
  padding:120px max(6vw,72px);
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:100px;
  align-items:end;
  background:var(--v2-paper);
}
.service-intro h2,.service-section-heading h2,.service-faq h2 {
  max-width:760px;
  margin:0;
  font:500 clamp(39px,4vw,62px)/1.08 "Manrope",sans-serif;
  letter-spacing:-3.4px;
}
.service-intro > p {
  max-width:650px;
  margin:0 0 5px;
  color:#62625e;
  font-size:16px;
  line-height:1.9;
}
.service-highlights {
  padding:0 max(6vw,72px) 120px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  background:var(--v2-paper);
}
.service-highlights article {
  min-height:270px;
  padding:34px;
  display:flex;
  flex-direction:column;
  border-radius:17px;
  background:white;
  border:1px solid rgba(23,22,21,.06);
  box-shadow:0 13px 35px rgba(23,22,21,.04);
}
.service-highlights article:first-child { color:white; background:var(--v2-ink); }
.service-highlights article > span { color:#a0a09b; font-size:9px; letter-spacing:1px; }
.service-highlights h2 { margin:auto 0 10px; font-size:22px; letter-spacing:-.7px; }
.service-highlights p { margin:0; color:#73736e; font-size:13px; line-height:1.7; }
.service-highlights article:first-child p { color:rgba(255,255,255,.62); }
.service-process { padding:120px max(6vw,72px); background:white; }
.service-section-heading { max-width:850px; margin-bottom:75px; }
.service-process ol { margin:0; padding:0; display:grid; grid-template-columns:repeat(4,1fr); list-style:none; border-top:1px solid var(--v2-silver); }
.service-process li { position:relative; padding:45px 32px 10px; }
.service-process li+li { border-left:1px solid var(--v2-silver); }
.service-process li > span {
  position:absolute;
  top:-18px;
  left:30px;
  width:36px;
  height:36px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:var(--v2-yellow);
  font-size:9px;
  font-weight:800;
}
.service-process h3 { margin:8px 0 13px; font-size:17px; }
.service-process li p { margin:0; color:#70706b; font-size:12px; line-height:1.75; }
.service-faq {
  padding:120px max(6vw,72px);
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:100px;
  background:var(--v2-mineral);
}
.service-faq-list { border-top:1px solid #bdc1bb; }
.service-faq details { border-bottom:1px solid #bdc1bb; }
.service-faq summary { padding:25px 0; cursor:pointer; list-style:none; font-size:15px; font-weight:700; }
.service-faq summary::-webkit-details-marker { display:none; }
.service-faq summary span { float:right; color:#a87800; font-size:22px; }
.service-faq details[open] summary span { transform:rotate(45deg); }
.service-faq details p { max-width:670px; margin:0; padding:0 50px 25px 0; color:#62625e; font-size:13px; line-height:1.8; }
.service-related { padding:110px max(6vw,72px); background:var(--v2-paper); }
.service-related > div:last-child { border-top:1px solid #c7cac5; }
.service-related > div:last-child a {
  padding:25px 5px;
  display:grid;
  grid-template-columns:70px 1fr auto;
  align-items:center;
  text-decoration:none;
  border-bottom:1px solid #c7cac5;
  transition:padding .2s,background .2s;
}
.service-related > div:last-child a:hover { padding-inline:18px; background:white; }
.service-related a span { color:#999994; font-size:9px; }
.service-related a strong { font-size:clamp(19px,2vw,28px); font-weight:500; letter-spacing:-.8px; }
.service-related a i { color:#9c7000; font-size:24px; font-style:normal; }
.service-contact-banner { margin:0; }

@media (max-width: 1050px) {
  .v2-header { grid-template-columns:260px 1fr; }.v2-header-cta { display:none; }
  .v2-hero { grid-template-columns:48% 52%; min-height:680px; }.v2-hero-copy { padding-inline:45px; }.v2-hero h1 { font-size:55px; }
  .v2-service-grid { grid-template-columns:repeat(2,1fr); }.v2-service-card:nth-child(2),.v2-service-card:nth-child(5),.v2-service-card:nth-child(8) { transform:none; }
  .v2-contact-banner { grid-template-columns:auto 1fr auto; }.v2-contact-banner > a:not(.v2-button) { display:none; }
  .service-hero { grid-template-columns:58% 42%; }.service-hero-copy { padding-inline:55px; }
  .service-intro,.service-faq { gap:55px; }
  .service-process ol { grid-template-columns:repeat(2,1fr); row-gap:55px; }
  .service-process li:nth-child(3) { border-left:0; }
}
@media (max-width: 760px) {
  .v2-header,.v2-header.scrolled { position:absolute; height:82px; padding:0 20px; grid-template-columns:220px 1fr; }.v2-logo { height:64px; }
  .v2-menu-button { display:block; }.v2-menu-button > span:not(.sr-only) { background:var(--v2-ink); }
  .v2-nav { position:absolute; top:82px; left:0; right:0; display:none; padding:28px; flex-direction:column; align-items:flex-start; background:white; box-shadow:0 20px 35px rgba(23,22,21,.1); }.v2-nav.open { display:flex; }
  .v2-hero { padding-top:82px; display:flex; min-height:0; flex-direction:column; }.v2-hero-copy { padding:82px 24px 65px; }.v2-hero h1 { font-size:47px; letter-spacing:-3.4px; }.v2-actions { align-items:flex-start; flex-direction:column; gap:18px; }
  .v2-hero-media { min-height:430px; clip-path:polygon(0 6%,100% 0,100% 100%,0 100%); }.v2-avatar { width:85px; height:85px; }
  .v2-pixels-hero { top:105px; left:auto; right:15px; }
  .v2-trust { width:calc(100% - 30px); margin:-10px auto 0; grid-template-columns:1fr; }.v2-trust > div { justify-content:flex-start; }.v2-trust > div+div { border-left:0; border-top:1px solid var(--v2-silver); }
  .v2-services,.v2-process,.v2-projects { padding:85px 20px; background:var(--v2-paper); }.v2-section-intro,.v2-project-heading { display:block; margin-bottom:45px; }.v2-section-intro h2,.v2-about h2,.v2-projects h2,.v2-contact h2 { font-size:41px; letter-spacing:-2.7px; }.v2-section-intro > p,.v2-project-heading > p { margin-top:25px; }
  .v2-service-grid { grid-template-columns:1fr; }.v2-service-card { min-height:305px; }
  .v2-about { grid-template-columns:1fr; }.v2-about-media { min-height:430px; }.v2-about-copy { padding:75px 24px; }.v2-facts { grid-template-columns:1fr; gap:15px; }.v2-facts div+div { padding:15px 0 0; border-left:0; border-top:1px solid var(--v2-silver); }
  .v2-process-list { grid-template-columns:1fr; border-top:0; }.v2-process-list li { padding:20px 0 25px 55px; border-top:1px solid #cfd2cd; }.v2-process-list li+li { border-left:0; }.v2-process-list > li > span { top:18px; left:0; }
  .v2-project-grid { height:auto; grid-template-columns:1fr; grid-template-rows:360px 220px 220px; }.v2-project-1 { grid-row:auto; }.v2-project-4,.v2-project-5 { display:none; }
  .v2-project-grid { grid-template-rows:360px repeat(4,220px); }
  .v2-project-4,.v2-project-5 { display:block; }
  .v2-more-projects { margin-top:55px; }
  .v2-project-rail { margin-inline:-20px; padding-inline:20px; }
  .v2-rail-card { flex-basis:82vw; }
  .v2-rail-heading p:last-child { display:none; }
  .v2-rail-controls button { width:43px; height:43px; }
  .v2-lightbox { width:calc(100% - 24px); height:calc(100% - 70px); }
  .v2-lightbox-arrow { top:auto; bottom:7px; width:44px; height:44px; transform:none; border-radius:50%; }
  .v2-lightbox-arrow.previous { left:auto; right:65px; }.v2-lightbox-arrow.next { right:14px; }
  .v2-lightbox figcaption { padding-right:120px; }
  .v2-contact-banner { padding:35px 22px; grid-template-columns:auto 1fr; }.v2-contact-banner .v2-button { grid-column:1/3; }.v2-contact-banner h2 { font-size:28px; }
  .v2-contact { grid-template-columns:1fr; }.v2-contact-copy,.v2-contact-form { padding:75px 24px; }.v2-direct { grid-template-columns:1fr; }.v2-direct > div { grid-column:auto; }
  .v2-footer { padding:50px 24px 25px; }.v2-footer-main { grid-template-columns:1fr; gap:25px; }.v2-footer-main img { width:min(250px,100%); height:auto; }.v2-footer-main p { grid-column:auto; margin:0; }.v2-footer-main > a { justify-self:start; }.v2-footer-details { flex-direction:column; gap:5px; }
  .back-to-top { right:15px; bottom:calc(15px + env(safe-area-inset-bottom)); width:48px; min-height:48px; padding:4px; border-radius:50%; }
  .back-to-top span { width:40px; height:40px; }
  .back-to-top strong { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }
  .service-hero { padding-top:82px; display:flex; min-height:0; flex-direction:column; }
  .service-hero-copy { padding:65px 24px 70px; }
  .service-breadcrumbs { margin-bottom:45px; }
  .service-hero h1 { font-size:46px; letter-spacing:-3.2px; }
  .service-hero-media { min-height:390px; }
  .service-intro,.service-faq { padding:80px 24px; display:block; }
  .service-intro h2,.service-section-heading h2,.service-faq h2 { font-size:39px; letter-spacing:-2.5px; }
  .service-intro > p { margin-top:30px; font-size:14px; }
  .service-highlights { padding:0 20px 80px; grid-template-columns:1fr; }
  .service-highlights article { min-height:235px; }
  .service-process,.service-related { padding:80px 24px; }
  .service-section-heading { margin-bottom:55px; }
  .service-process ol { grid-template-columns:1fr; border-top:0; row-gap:0; }
  .service-process li { padding:24px 0 28px 55px; border-top:1px solid var(--v2-silver); }
  .service-process li+li,.service-process li:nth-child(3) { border-left:0; }
  .service-process li > span { top:20px; left:0; }
  .service-faq-list { margin-top:50px; }
  .service-related > div:last-child a { grid-template-columns:45px 1fr auto; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior:auto; }
  .back-to-top { transition:none; }
}

/* CMS – matching light industrial identity */
.admin-body {
  --admin-yellow:#fbb900;
  --admin-ink:#171615;
  --admin-paper:#f2f2ee;
  --admin-line:#dfe1dc;
  background:var(--admin-paper);
  color:var(--admin-ink);
  font-family:"Manrope",sans-serif;
}
.admin-sidebar { width:264px; padding:26px 22px; color:var(--admin-ink); background:#fff; border-right:1px solid var(--admin-line); }
.admin-logo { display:block; height:74px; overflow:hidden; }
.admin-logo img { width:100%; height:auto; }
.admin-sidebar > p { margin:0 12px 30px; color:#92928e; font:400 8px "Bungee",sans-serif; letter-spacing:1.2px; }
.admin-sidebar nav { gap:4px; }
.admin-sidebar a { color:#666661; font-size:12px; font-weight:600; border-radius:9px; }
.admin-sidebar nav a:hover { color:var(--admin-ink); background:#f3f3ef; }
.admin-sidebar nav a:before { content:""; display:inline-block; width:5px; height:5px; margin:0 11px 2px 0; border-radius:50%; background:#c4c6c1; }
.admin-sidebar nav a:hover:before { background:var(--admin-yellow); }
.admin-sidebar b { background:var(--admin-yellow); color:var(--admin-ink); }
.admin-sidebar > div { padding-top:18px; border-top:1px solid var(--admin-line); }
.admin-sidebar > div a:last-child { color:#a24f40; }
.admin-main { margin-left:264px; padding:48px clamp(28px,5vw,78px) 110px; }
.admin-main > header { max-width:1160px; margin-bottom:30px; }
.admin-main > header p { color:#a67a00; font:400 9px "Bungee",sans-serif; letter-spacing:1.4px; }
.admin-main > header h1 { margin-top:7px; font-size:29px; font-weight:600; letter-spacing:-1.5px; }
.admin-preview-button { padding:13px 18px; color:#fff; background:var(--admin-ink); text-decoration:none; font-size:11px; font-weight:700; }
.admin-header-actions { display:flex; align-items:center; gap:10px; }
.admin-quick-button { padding:13px 18px; color:var(--admin-ink); background:var(--admin-yellow); text-decoration:none; font-size:11px; font-weight:700; }
.admin-overview { max-width:1160px; margin:0 auto 24px; display:grid; grid-template-columns:.65fr .65fr 1fr 1.7fr; background:#fff; border:1px solid var(--admin-line); border-radius:16px; overflow:hidden; }
.admin-overview > div { min-height:94px; padding:20px 24px; display:flex; align-items:center; gap:14px; }
.admin-overview > div+div { border-left:1px solid var(--admin-line); }
.admin-overview span { font-size:30px; font-weight:600; letter-spacing:-2px; }
.admin-overview p { margin:0; color:#777772; font-size:10px; line-height:1.45; }
.admin-overview > div:last-child i { flex:0 0 10px; width:10px; height:10px; border-radius:50%; background:#d0644e; box-shadow:0 0 0 5px #f8e9e5; }
.admin-overview > div:last-child.configured i { background:#63a56c; box-shadow:0 0 0 5px #e8f2e9; }
.admin-overview > div:last-child p { display:grid; }
.admin-overview strong { color:var(--admin-ink); font-size:11px; }
.admin-overview small { color:#a24f40; font-size:9px; }
.admin-overview .configured small { color:#4c8954; }
.admin-notice { max-width:1160px; margin:0 auto 24px; padding:16px 20px; color:#654f13; background:#fff5d5; border:1px solid #ecd680; border-radius:12px; font-size:11px; line-height:1.6; }
.admin-notice strong { margin-right:5px; }
.admin-notice code { padding:2px 5px; color:var(--admin-ink); background:rgba(255,255,255,.7); }
.admin-panel { max-width:1160px; margin-bottom:24px; padding:38px; border:1px solid rgba(23,22,21,.05); border-radius:18px; box-shadow:0 12px 40px rgba(23,22,21,.04); }
.panel-heading { align-items:center; border-color:#e7e8e4; }
.panel-heading span { color:#a67a00; font:400 8px "Bungee",sans-serif; letter-spacing:1.4px; }
.panel-heading h2 { margin-top:7px; font-size:20px; font-weight:600; letter-spacing:-.7px; }
.panel-heading > p { color:#858580; }
.admin-body .button.primary { color:var(--admin-ink); background:var(--admin-yellow); border-radius:0; }
.admin-body .button.primary:hover { background:#ffc82e; }
.admin-body .button.outline { border-color:#cdd0ca; border-radius:0; font-size:11px; }
.editor-form input,.editor-form textarea,.editor-form select { padding:12px 13px; border:1px solid #d5d8d2; border-radius:7px; background:#fafaf8; }
.editor-form input:focus,.editor-form textarea:focus,.editor-form select:focus { border-color:#bc8a00; box-shadow:0 0 0 3px rgba(251,185,0,.13); }
.editor-form label { color:#696964; font-size:9px; }
.editor-form label > small { color:#92928d; font-size:9px; font-weight:500; text-transform:none; letter-spacing:0; }
.email-security-options { display:flex; flex-wrap:wrap; gap:12px 28px; padding:6px 0 15px; }
.email-security-options .check { margin:0; }
.danger-check { color:#a24f40!important; }
.email-test-form { margin-top:18px; padding-top:20px; display:flex; align-items:center; gap:15px; border-top:1px solid var(--admin-line); }
.email-test-form span { color:#92928d; font-size:9px; }
.email-test-form button:disabled { opacity:.45; cursor:not-allowed; }
.item-list { gap:9px; }
.item-editor { border-color:#e0e2dd; border-radius:11px; overflow:hidden; }
.item-editor summary { min-height:57px; padding:10px 17px; grid-template-columns:38px 1fr auto; background:#fff; }
.item-editor summary strong { font-size:12px; }
.item-editor[open] summary { background:#fafaf7; }
.compact-form { padding:25px; background:#f7f7f4; border-color:#e0e2dd; }
.admin-image-thumb { width:36px; height:36px; border-radius:6px; object-fit:cover; }
.admin-image-preview { position:relative; width:220px; margin:0 0 22px; overflow:hidden; border-radius:10px; background:#ddd; }
.admin-image-preview img { width:220px; height:135px; object-fit:cover; }
.admin-image-preview span { position:absolute; left:8px; bottom:8px; padding:4px 7px; color:#fff; background:rgba(0,0,0,.68); border-radius:4px; font-size:8px; text-transform:uppercase; letter-spacing:.7px; }
.admin-upload-field { padding:18px; background:#fff; border:1px dashed #b6bbb3; border-radius:9px; }
.admin-upload-field input { padding:8px; background:#f5f5f1; }
.admin-upload-field small { color:#90908b; font-size:9px; text-transform:none; letter-spacing:0; font-weight:500; }
.inquiry { border-color:#e1e3de; }
.inquiry summary { padding:17px 8px; }
.inquiry summary i { background:var(--admin-yellow); }
.inquiry.read summary i { background:#c7cac5; }

.login-body { background:var(--v2-paper); }
.login-body:before { content:""; position:fixed; inset:0 52% 0 0; background:var(--v2-yellow); clip-path:polygon(0 0,100% 0,80% 100%,0 100%); }
.login-shell { position:relative; padding:34px max(5vw,42px); }
.login-logo { position:relative; z-index:2; display:block; width:290px; height:90px; overflow:hidden; }
.login-logo img { width:100%; }
.login-card { width:min(480px,100%); padding:52px; border-radius:18px; box-shadow:0 28px 80px rgba(23,22,21,.13); }
.login-kicker { margin:0 0 22px; color:#987000; font:400 9px "Bungee",sans-serif; letter-spacing:1.4px; text-transform:uppercase; }
.login-card h1 { font-weight:600; letter-spacing:-2px; }
.login-card input { border-radius:7px; }
.login-card .v2-button { width:100%; margin-top:12px; }

/* Mobile-first quick image upload */
.quick-upload-body { min-height:100vh; background:#f1f1ed; }
.quick-upload-header {
  height:76px;
  padding:0 max(20px,4vw);
  display:grid;
  grid-template-columns:1fr 240px 1fr;
  align-items:center;
  gap:20px;
  background:#fff;
  border-bottom:1px solid var(--admin-line);
}
.quick-upload-header img { width:220px; margin:auto; }
.quick-upload-header a { color:#686864; text-decoration:none; font-size:11px; font-weight:700; }
.quick-upload-header a:last-child { justify-self:end; }
.quick-upload-main { width:min(760px,calc(100% - 32px)); margin:0 auto; padding:60px 0 100px; }
.quick-upload-intro { margin-bottom:30px; }
.quick-upload-intro > p { margin:0 0 13px; color:#9c7300; font:400 9px "Bungee",sans-serif; letter-spacing:1.4px; text-transform:uppercase; }
.quick-upload-intro h1 { max-width:680px; margin:0; font:600 clamp(35px,6vw,58px)/1.05 "Manrope",sans-serif; letter-spacing:-3px; }
.quick-upload-intro > span { display:block; max-width:610px; margin-top:20px; color:#757570; font-size:12px; line-height:1.7; }
.quick-upload-form { padding:28px; background:#fff; border:1px solid var(--admin-line); border-radius:18px; box-shadow:0 18px 55px rgba(23,22,21,.06); }
.quick-file-picker {
  min-height:250px;
  padding:35px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  cursor:pointer;
  border:2px dashed #bdc0b9;
  border-radius:14px;
  background:#f8f8f5;
  transition:border-color .2s,background .2s;
}
.quick-file-picker:hover { border-color:#a77b00; background:#fffaf0; }
.quick-file-picker input { position:absolute; width:1px; height:1px; opacity:0; pointer-events:none; }
.quick-camera-icon { width:62px; height:62px; margin-bottom:18px; display:grid; place-items:center; border-radius:50%; color:#171615; background:var(--admin-yellow); font-size:31px; line-height:1; }
.quick-file-picker strong { font-size:16px; }
.quick-file-picker small { margin-top:7px; color:#858580; font-size:10px; }
.quick-preview { margin-top:18px; }
.quick-preview[hidden],.quick-batch-controls[hidden] { display:none!important; }
.quick-image-list { display:grid; gap:14px; }
.quick-image-card { display:grid; grid-template-columns:230px 1fr; overflow:hidden; border:1px solid var(--admin-line); border-radius:13px; background:#fafaf8; }
.quick-image-card figure { position:relative; min-width:0; min-height:100%; margin:0; overflow:hidden; background:#dfe1dc; }
.quick-image-card figure img { width:100%; height:100%; min-height:300px; object-fit:cover; }
.quick-image-card figure > span { position:absolute; top:12px; left:12px; width:34px; height:34px; display:grid; place-items:center; border-radius:50%; background:var(--admin-yellow); font-size:9px; font-weight:800; }
.quick-image-card figcaption { position:absolute; inset:auto 0 0; padding:35px 12px 11px; overflow:hidden; color:#fff; background:linear-gradient(transparent,rgba(0,0,0,.7)); font-size:8px; text-overflow:ellipsis; white-space:nowrap; }
.quick-image-fields { padding:22px; }
.quick-image-heading { margin-bottom:17px; display:flex; align-items:center; justify-content:space-between; gap:20px; }
.quick-image-heading strong { font-size:14px; }
.quick-image-heading button { padding:6px 0; border:0; color:#a24f40; background:transparent; font-size:9px; font-weight:700; cursor:pointer; }
.quick-batch-controls { margin:25px 0 5px; padding:20px; display:grid; grid-template-columns:1.1fr 1fr 1fr auto; align-items:end; gap:14px; border:1px solid #ead58c; border-radius:12px; background:#fff8df; }
.quick-batch-controls > div { align-self:center; display:grid; }
.quick-batch-controls > div span { color:#9c7300; font:400 8px "Bungee",sans-serif; letter-spacing:1px; text-transform:uppercase; }
.quick-batch-controls > div strong { margin-top:4px; font-size:11px; }
.quick-batch-controls label,.quick-image-fields > label,.quick-advanced label {
  display:grid;
  gap:7px;
  margin-bottom:17px;
  color:#686864;
  font-size:9px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
}
.quick-batch-controls label { margin:0; }
.quick-batch-controls input,.quick-batch-controls select,.quick-image-fields input,.quick-image-fields select {
  min-width:0;
  padding:12px 11px;
  border:1px solid #d1d4ce;
  border-radius:8px;
  background:#fff;
}
.quick-batch-controls button { min-height:43px; padding:0 15px; border:0; color:#171615; background:var(--admin-yellow); font-size:9px; font-weight:800; cursor:pointer; }
.quick-selection-note { min-height:18px; margin:10px 0 0; color:#7d7d78; text-align:center; font-size:9px; }
.quick-image-fields label small { color:#969691; font-size:9px; font-weight:500; letter-spacing:0; text-transform:none; }
.quick-alt-preview { margin:5px 0 20px; padding:17px; display:grid; gap:5px; border-left:4px solid var(--admin-yellow); background:#f6f6f2; }
.quick-alt-preview span { color:#92928d; font-size:8px; font-weight:700; letter-spacing:1px; text-transform:uppercase; }
.quick-alt-preview strong { font-size:12px; }
.quick-advanced { margin:0 0 25px; border-bottom:1px solid var(--admin-line); }
.quick-advanced summary { padding:12px 0; cursor:pointer; color:#767671; font-size:10px; font-weight:700; }
.quick-advanced label { margin-top:12px; }
.quick-publish-button {
  width:100%;
  min-height:58px;
  padding:0 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  border:0;
  color:#171615;
  background:var(--admin-yellow);
  font-size:13px;
  font-weight:800;
  cursor:pointer;
}
.quick-publish-button:disabled { opacity:.65; cursor:wait; }
.quick-publish-button span { font-size:20px; }
.quick-upload-status { min-height:18px; margin:10px 0 0; color:#777772; text-align:center; font-size:9px; }

@media (max-width:720px) {
  .admin-sidebar { width:auto; padding:14px 18px; min-height:74px; }
  .admin-logo { width:205px; height:55px; }
  .admin-sidebar > div { padding:0; border:0; }
  .admin-main { margin:0; padding:28px 12px 70px; }
  .admin-main > header { padding:0 5px; }
  .admin-preview-button { display:none; }
  .admin-header-actions { width:100%; }.admin-quick-button { width:100%; text-align:center; }
  .admin-overview { grid-template-columns:1fr 1fr; }
  .admin-overview > div { min-height:78px; padding:15px; }
  .admin-overview > div:nth-child(3) { border-left:0; border-top:1px solid var(--admin-line); }
  .admin-overview > div:nth-child(4) { border-top:1px solid var(--admin-line); }
  .admin-panel { padding:24px 16px; }
  .admin-image-preview,.admin-image-preview img { width:100%; }
  .admin-image-preview img { height:190px; }
  .login-body:before { inset:0 0 64% 0; clip-path:polygon(0 0,100% 0,100% 75%,0 100%); }
  .login-card { padding:34px 24px; }
  .quick-upload-header { height:68px; padding:0 14px; grid-template-columns:1fr 145px 1fr; gap:8px; }
  .quick-upload-header img { width:145px; }
  .quick-upload-header a { font-size:9px; }.quick-upload-header a:last-child { font-size:0; }.quick-upload-header a:last-child:after { content:"Webb ↗"; font-size:9px; }
  .quick-upload-main { width:calc(100% - 20px); padding:35px 0 70px; }
  .quick-upload-intro { padding:0 7px; }
  .quick-upload-intro h1 { font-size:38px; letter-spacing:-2.3px; }
  .quick-upload-form { padding:13px; border-radius:14px; }
  .quick-file-picker { min-height:230px; padding:25px 15px; }
  .quick-batch-controls { grid-template-columns:1fr; }
  .quick-batch-controls > div { margin-bottom:5px; }
  .quick-image-card { grid-template-columns:1fr; }
  .quick-image-card figure { min-height:240px; }
  .quick-image-card figure img { height:260px; min-height:0; }
  .quick-image-fields { padding:18px 14px; }
  .quick-camera-icon { width:58px; height:58px; }
}
