:root{
--accent:#005964;
--accentRgb:0,89,100;
--bg:#ffffff;
--text:#0b0b0b;
--muted:#4b5563;
--card:#f7fafb;
--border:#e5e7eb;
--shadow:0 10px 30px rgba(0,0,0,.06);
--shadow2:0 18px 55px rgba(0,0,0,.09);
--radius:18px;
--max:1120px;
--call:#16a34a;
--bg1Opacity:0;
--bg2Opacity:0;
--bg1Y:0px;
--bg2Y:0px;
--bgSide1X:0px;
--bgSide2X:0px;
--footerShade:0;
--cursorDefault:url("/assets/cursor.png");
--cursorClick:url("/assets/cursor_click.png");
--cursorGrab:url("/assets/cursor_grab.png");
}

*{box-sizing:border-box}

html{
margin:0;
padding:0;
height:100%;
background:#ffffff;
}

body{
margin:0;
padding:0;
font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
color:var(--text);
background:transparent;
height:100%;
}

a{color:inherit;text-decoration:none}

html,body,*,:before,:after{cursor:none!important}

body{
position:relative;
overflow-x:hidden;
background:transparent;
user-select:none;
-webkit-user-select:none;
min-height:100vh;
display:flex;
flex-direction:column;
}

*{
scrollbar-width:auto;
scrollbar-color:rgba(var(--accentRgb),.85) rgba(15,23,42,.06);
}

::-webkit-scrollbar{
width:14px;
height:10px;
}
::-webkit-scrollbar-track{
background:rgba(15,23,42,.03);
border-radius:999px;
}
::-webkit-scrollbar-thumb{
background:linear-gradient(180deg, rgba(var(--accentRgb),.55), rgba(var(--accentRgb),.95));
border-radius:999px;
border:3px solid rgba(248,250,252,.95);
box-shadow:0 0 0 1px rgba(15,23,42,.04);
transition:border-width .15s ease, box-shadow .15s ease;
}
::-webkit-scrollbar-thumb:hover{
border-width:1px;
box-shadow:0 0 0 2px rgba(0,89,100,.25);
}
::-webkit-scrollbar-button{
height:18px;
background-color:rgba(248,250,252,.96);
border:1px solid rgba(226,232,240,.9);
background-repeat:no-repeat;
background-position:center;
background-size:8px 8px;
}
::-webkit-scrollbar-button:single-button:vertical:decrement{
border-radius:999px 999px 0 0;
background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23005964' d='M7 15l5-6 5 6z'/%3E%3C/svg%3E");
}
::-webkit-scrollbar-button:single-button:vertical:increment{
border-radius:0 0 999px 999px;
background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23005964' d='M7 9l5 6 5-6z'/%3E%3C/svg%3E");
}

body.modal-open{overflow:hidden}
main{flex:1 0 auto;position:relative;z-index:0}
input,textarea{user-select:text;-webkit-user-select:text}
img{user-select:none;-webkit-user-drag:none;-webkit-touch-callout:none}

#customCursor{
position:fixed;
left:0;
top:0;
width:28px;
height:28px;
pointer-events:none;
z-index:9999;
opacity:0;
background-image:var(--cursorDefault);
background-repeat:no-repeat;
background-size:28px 28px;
will-change:transform,opacity,filter;
transform:translate3d(-100px,-100px,0) translate3d(-6px,-2px,0) scale(1);
transition:opacity .12s ease, filter .12s ease;
filter:drop-shadow(0 8px 18px rgba(0,0,0,.18));
}
#customCursor.on{opacity:1}
#customCursor.clicking{background-image:var(--cursorClick)}
#customCursor.grabbing{background-image:var(--cursorGrab)}

@media (any-hover:none) and (any-pointer:coarse){
html,body,*,:before,:after{cursor:auto!important}
#customCursor{display:none}
}

body::before{
content:"";
position:fixed;
inset:0;
background-image:radial-gradient(circle at 10% 0%, rgba(var(--accentRgb),.26), transparent 60%),url("/assets/background_1.png");
background-repeat:no-repeat;
background-size:150% 150%,cover;
background-position:0 0,center var(--bg1Y);
opacity:var(--bg1Opacity);
pointer-events:none;
z-index:-3;
}

body::after{
content:"";
position:fixed;
left:0;
right:0;
top:0;
bottom:0;
background-image:linear-gradient(to bottom, rgba(15,23,42,.12), transparent 42%),url("/assets/background_2.png");
background-repeat:no-repeat;
background-size:150% 150%,cover;
background-position:center 0,center var(--bg2Y);
opacity:var(--bg2Opacity);
pointer-events:none;
z-index:-2;
mask-image:linear-gradient(to bottom, transparent 0%, rgba(0,0,0,.08) 16%, rgba(0,0,0,1) 82%);
}

main::before,
main::after{
content:"";
position:fixed;
top:-10vh;
bottom:-10vh;
width:26vw;
pointer-events:none;
opacity:.7;
background:radial-gradient(circle at center, rgba(var(--accentRgb),.18), transparent 65%);
filter:blur(24px);
z-index:-1;
transform:translate3d(0,0,0);
}
main::before{
left:-16vw;
transform:translate3d(var(--bgSide1X),0,0);
}
main::after{
right:-16vw;
transform:translate3d(var(--bgSide2X),0,0);
}
body.plain-page main::before,
body.plain-page main::after{
display:none;
}

.container{max-width:var(--max);margin:0 auto;padding:0 18px}
.narrow{max-width:860px}

.topbar{position:sticky;top:0;background:rgba(255, 255, 255, 0.205);backdrop-filter:saturate(1.2) blur(10px);border-bottom:1px solid var(--border);z-index:20}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.2px}
.brand-logo{width:26px;height:26px;object-fit:contain;display:block}

.nav{display:flex;align-items:center;gap:14px}
.nav a{font-size:14px;color:var(--muted)}
.nav a:hover{color:var(--text)}
.pill{padding:9px 12px;border:1px solid var(--border);border-radius:999px;background:rgba(255, 255, 255, 0.178)}
.inline{display:inline}
.linkbtn{background:none;border:none;color:var(--muted);font:inherit;padding:0}
.linkbtn:hover{color:var(--text)}

.hero{padding:56px 0 18px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:26px;align-items:center}
h1{font-size:44px;line-height:1.05;margin:0 0 14px}
.accent{color:var(--accent)}
.lead{font-size:18px;color:var(--muted);margin:0 0 16px}
.cta-row{display:flex;gap:12px;flex-wrap:wrap}

.btn{
display:inline-flex;
align-items:center;
justify-content:center;
gap:10px;
border-radius:12px;
padding:12px 16px;
border:1px solid var(--border);
font-weight:800;
transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.primary.soft{background:rgba(var(--accentRgb),.78);border-color:rgba(var(--accentRgb),.78);color:#fff}
.btn.ghost{background:rgba(255,255,255,.9);border-color:rgba(var(--accentRgb),.18)}
.btn.small{padding:8px 10px;border-radius:10px;font-size:12px}
.btn.full{width:100%}
.btn:hover{box-shadow:var(--shadow2);transform:translateY(-1px)}
.btn:focus{outline:2px solid rgba(0,89,100,.22);outline-offset:2px}

.btn.call{background:var(--call);border-color:var(--call);color:#fff}
.btn.call:hover{filter:brightness(1.03)}

.btn.danger{
background:#dc2626;
border-color:#b91c1c;
color:#fff;
}
.btn.danger:hover{
filter:brightness(1.03);
box-shadow:var(--shadow2);
transform:translateY(-1px);
}

.card{
background:rgba(4, 81, 107, 0.342);
border:1px solid var(--border);
border-radius:var(--radius);
box-shadow:var(--shadow);
padding:16px;
transition:transform .2s ease, box-shadow .2s ease;
}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow2)}

.hero-card{
padding:0;
border-radius:26px;
overflow:hidden;
background:#045b75cb;
border:1px solid rgba(var(--accentRgb),.28);
box-shadow:var(--shadow2);
position:relative;
aspect-ratio:16 / 11;
}
.hero-img{
width:100%;
height:100%;
display:block;
object-fit:cover;
border-radius:0;
transform:none;
transform-origin:center;
}

.hero-sub{margin-top:10px;color:var(--muted);font-size:14px;line-height:1.45;max-width:50ch}

.muted{color:var(--muted)}
.small{font-size:13px}

.section{padding:56px 0}
.section.alt{
background:radial-gradient(circle at top, rgba(255,255,255,.2), rgba(255,255,255,.04));
backdrop-filter:saturate(1.08) blur(4px);
}
.section.alt .card{
background:rgba(255, 255, 255, 0.144);
border-color:rgba(var(--accentRgb),.18);
box-shadow:var(--shadow2);
}
.section-head{
margin-bottom:34px;
text-align:center;
}
.section-head h2{
margin:0 0 14px;
font-size:32px;
font-weight:600;
letter-spacing:.16em;
text-transform:uppercase;
position:relative;
display:inline-block;
padding:0 14px;
}
.section-head h2::after{
content:"";
position:absolute;
left:50%;
bottom:-12px;
width:92px;
height:3px;
border-radius:999px;
transform:translateX(-50%);
background:linear-gradient(90deg, rgba(var(--accentRgb),.06), rgba(var(--accentRgb),.9), rgba(var(--accentRgb),.06));
}
.section-head p{
margin-top:18px;
margin-bottom:0;
font-size:15px;
line-height:1.6;
color:var(--muted);
}
.section-head p.muted{
max-width:560px;
margin-left:auto;
margin-right:auto;
}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}

.form label{display:flex;flex-direction:column;gap:6px;margin-top:12px}
.form input,.form select,.form textarea{
border:1px solid var(--border);
border-radius:12px;
padding:12px 12px;
font-size:15px;
background:#fff;
transition:border-color .16s ease, box-shadow .16s ease, background .16s ease;
}
.form input[type=number]{appearance:textfield;-moz-appearance:textfield}
.form input[type=number]::-webkit-outer-spin-button,
.form input[type=number]::-webkit-inner-spin-button{appearance:none;margin:0}
.form textarea{resize:vertical}

.form input:hover,
.form select:hover,
.form textarea:hover{
background:#fff;
border-color:var(--border);
box-shadow:none;
}

.form input:focus,
.form select:focus,
.form textarea:focus{
outline:none;
border-color:rgba(var(--accentRgb),.55);
box-shadow:0 0 0 1px rgba(var(--accentRgb),.25);
background:#fff;
}

.form select,
.form input[list]{
appearance:none;
-webkit-appearance:none;
-moz-appearance:none;
background-image:url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20viewBox%3D%270%200%2020%2020%27%3E%3Cpath%20d%3D%27M5%207l5%206%205-6%27%20fill%3D%27none%27%20stroke%3D%27%230b0b0b%27%20stroke-width%3D%272%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27%2F%3E%3C%2Fsvg%3E");
background-repeat:no-repeat;
background-position:right 12px center;
background-size:14px 14px;
padding-right:40px;
}

.form select:required:invalid{color:var(--muted)}
.form select option{color:var(--text)}
.form select option[value=""]{color:var(--muted)}

.form input.invalid,.form select.invalid,.form textarea.invalid{
border-color:#dc2626;
box-shadow:0 0 0 1px rgba(220,38,38,.2);
background:#fff;
}
.form input.invalid:focus,.form select.invalid:focus,.form textarea.invalid:focus{
outline:2px solid rgba(220,38,38,.35);
outline-offset:1px;
}

.row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grow{grid-column:1/-1}

.alert{background:#fff;border:1px solid var(--border);border-left:4px solid var(--accent);padding:10px 12px;border-radius:12px;margin:10px 0;color:var(--text)}
.form-status{margin-top:10px}
.forgot-link{margin-top:10px;display:inline-flex;align-self:flex-start}

.container.about{max-width:980px}
.grid-2.about{gap:28px;align-items:center}
.about-card{display:flex;justify-content:center}
.about-media{
height:240px;
aspect-ratio:1365 / 2048;
border-radius:22px;
overflow:hidden;
background:rgba(15,23,42,.92);
box-shadow:var(--shadow2);
border:1px solid rgba(15,23,42,.6);
}
.about .portrait{
width:100%;
height:100%;
object-fit:cover;
background:transparent;
border-radius:22px;
display:block;
}

.sig{margin-top:14px;display:flex;align-items:center;justify-content:center;gap:12px}
.signature{width:306px;max-width:92%;height:auto;filter:contrast(1.05)}

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.steps .step.card{
position:relative;
overflow:hidden;
background:linear-gradient(135deg, rgba(var(--accentRgb),.04), rgb(255, 255, 255));
border:1px solid rgba(var(--accentRgb),.14);
box-shadow:var(--shadow),0 18px 50px rgba(255, 255, 255, 0.568);
transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
}
.steps .step.card::before{
content:"";
position:absolute;
inset:-40%;
background:radial-gradient(circle at 0 0, rgba(var(--accentRgb),.14), transparent 60%);
opacity:0;
transform:translate3d(-30px,-30px,0);
transition:opacity .28s ease, transform .28s ease;
}
.step img{
width:100%;
height:auto;
border-radius:16px;
border:1px solid rgba(255,255,255,.9);
background:#fff;
display:block;
transform:scale(1.02);
transition:transform .22s ease, filter .22s ease;
}
.step a{display:block}
.step h3{margin:12px 0 6px;display:flex;align-items:center;gap:10px}
.steps .step.card:hover{
transform:translateY(-4px);
box-shadow:var(--shadow2),0 26px 70px rgba(0, 88, 100, .55);
background:linear-gradient(135deg, rgba(var(--accentRgb),.09), rgb(255, 255, 255));
border-color:rgba(var(--accentRgb),.38);
}
.steps .step.card:hover::before{
opacity:1;
transform:translate3d(0,0,0);
}
.steps .step.card:hover img{
transform:scale(1.05) translateY(-2px);
filter:contrast(1.02) saturate(1.05);
}

.map-grid{display:grid;grid-template-columns:1fr;gap:12px;align-items:stretch}
.map{padding:0;overflow:hidden;border-radius:24px}
.map iframe{border:0;width:100%;height:min(62vh, 560px);display:block}
.copy-status{min-height:18px}

.final-cta-bar{padding:32px 0 40px}
.final-cta-btn{border-radius:20px;padding:26px 20px;font-size:24px;box-shadow:var(--shadow2)}

.gallery{margin-top:56px}
.gallery-shell{border:1px solid var(--border);border-radius:22px;background:rgba(0,89,100,.25);backdrop-filter:saturate(1.1) blur(10px);box-shadow:var(--shadow);padding:12px}
.gallery-viewport{
overflow:hidden;
border-radius:18px;
position:relative;
touch-action:pan-y pinch-zoom;
-webkit-mask-image:linear-gradient(to right, transparent 0%, rgba(0,0,0,1) 10%, rgba(0,0,0,1) 86%, transparent 100%);
mask-image:linear-gradient(to right, transparent 0%, rgba(0,0,0,1) 10%, rgba(0,0,0,1) 86%, transparent 100%);
}
.gallery-track{
display:flex;
gap:12px;
transform:translate3d(0,0,0);
transition:transform .72s ease;
will-change:transform;
padding:2px 2px 0 2px;
}
.gallery-track.dragging{transition:none}
.gallery-item{
flex:0 0 calc((100% - 12px) / 1.35);
aspect-ratio:16 / 10;
border-radius:18px;
overflow:hidden;
border:1px solid var(--border);
background:#fff;
}
.gallery-item img{width:100%;height:100%;object-fit:cover;display:block}
.gallery-dots{display:flex;gap:12px;justify-content:center;align-items:center;margin-top:12px}
.gallery-dot{
width:26px;
height:26px;
border-radius:999px;
border:1px solid rgba(229,231,235,.95);
background:rgba(255,255,255,.7);
padding:0;
display:grid;
place-items:center;
touch-action:manipulation;
}
.gallery-dot::before{
content:"";
width:8px;
height:8px;
border-radius:999px;
border:1px solid rgba(75,85,99,.25);
background:rgba(75,85,99,.12);
transition:transform .16s ease, box-shadow .16s ease, background .16s ease, border-color .16s ease;
}
.gallery-dot.on::before{
background:rgba(var(--accentRgb),.86);
border-color:rgba(var(--accentRgb),.35);
box-shadow:0 0 0 5px rgba(var(--accentRgb),.14);
transform:scale(1.02);
}
.gallery-dot:focus{outline:2px solid rgba(0,89,100,.22);outline-offset:2px}

.info-rows{
margin-top:46px;
display:flex;
flex-direction:column;
gap:22px;
}
.info-row{
position:relative;
border-radius:26px;
border:1px solid rgba(var(--accentRgb),.22);
background:linear-gradient(135deg, rgba(255,255,255,.97), rgba(255,255,255,.99));
box-shadow:var(--shadow2);
padding:24px 26px 22px;
overflow:hidden;
}
.info-row::before{
content:"";
position:absolute;
inset:-40%;
background:radial-gradient(circle at 0 0, rgba(var(--accentRgb),.18), transparent 64%);
opacity:0;
transform:translate3d(-32px,-18px,0);
transition:opacity .32s ease, transform .32s ease;
pointer-events:none;
}
.info-row:hover::before{
opacity:1;
transform:translate3d(0,0,0);
}
.info-row-inner{
position:relative;
display:flex;
align-items:center;
justify-content:space-between;
gap:28px;
}
.info-media{
flex:0 0 auto;
width:210px;
height:160px;
border-radius:24px;
border:1px solid rgba(var(--accentRgb),.18);
background:linear-gradient(135deg, rgba(255,255,255,.98), rgba(var(--accentRgb),.06));
display:flex;
align-items:center;
justify-content:center;
box-shadow:0 18px 38px rgba(0,0,0,.12);
overflow:hidden;
transform:translate3d(0,4px,0);
transition:transform .3s ease, box-shadow .3s ease;
}
.info-media img{
width:100%;
height:100%;
object-fit:cover;
display:block;
}
.info-row:hover .info-media{
transform:translate3d(0,-4px,0) scale(1.03);
box-shadow:0 24px 52px rgba(0,0,0,.18);
}
.info-content{
flex:1 1 auto;
max-width:680px;
margin:0 auto;
display:flex;
flex-direction:column;
align-items:flex-start;
text-align:left;
}
.info-label{
display:inline-flex;
align-items:center;
gap:6px;
padding:4px 12px;
border-radius:999px;
border:1px solid rgba(var(--accentRgb),.22);
background:rgba(var(--accentRgb),.06);
font-size:11px;
font-weight:800;
letter-spacing:.12em;
text-transform:uppercase;
color:rgba(15,23,42,.9);
margin-bottom:8px;
}
.info-label span{
font-size:10px;
opacity:.9;
}
.info-title{
margin:4px 0 10px;
font-size:22px;
}
.info-text{
margin:0;
font-size:15px;
line-height:1.6;
color:rgba(55,65,81,.95);
}
.info-text + .info-text{
margin-top:8px;
}

.callout{
display:flex;
flex-direction:column;
gap:10px;
background:rgba(0,89,100,.16);
backdrop-filter:saturate(1.15) blur(12px);
border-radius:24px;
padding:18px 20px;
border:1px solid rgba(var(--accentRgb),.22);
box-shadow:var(--shadow2);
color:rgba(255,255,255,.92);
text-align:center;
align-items:center;
}
.callout .muted{color:rgba(255,255,255,.78)}
.callout h3{margin:0;font-size:18px}

.catalog{margin-top:42px}
.catalog-shell{
border:1px solid var(--border);
border-radius:22px;
background:rgba(255,255,255,.86);
backdrop-filter:saturate(1.1) blur(10px);
box-shadow:var(--shadow);
padding:12px;
}
.catalog-viewport{
overflow-x:auto;
-webkit-overflow-scrolling:touch;
padding-bottom:6px;
}
.catalog-track{
display:flex;
gap:12px;
scroll-snap-type:x mandatory;
padding:2px 2px 10px;
}
.catalog-item{
flex:0 0 min(280px,80%);
scroll-snap-align:start;
border-radius:18px;
border:1px solid var(--border);
background:rgba(255,255,255,.96);
box-shadow:var(--shadow);
overflow:hidden;
display:flex;
flex-direction:column;
}
.catalog-card-btn{
background:none;
border:none;
padding:0;
margin:0;
text-align:left;
color:inherit;
width:100%;
display:flex;
flex-direction:column;
height:100%;
}
.catalog-thumb{
position:relative;
overflow:hidden;
}
.catalog-thumb img{
width:100%;
height:190px;
object-fit:cover;
display:block;
transform:scale(1);
transition:transform .22s ease, filter .22s ease;
}
.catalog-card-btn:hover .catalog-thumb img{transform:scale(1.03);filter:contrast(1.02)}
.catalog-body{
padding:12px 12px 14px;
}
.catalog-title{
margin:0 0 4px;
font-size:16px;
}
.catalog-subtitle{
margin:0 0 8px;
font-size:13px;
color:var(--muted);
}
.catalog-meta{
display:flex;
flex-wrap:wrap;
gap:6px 10px;
font-size:12px;
color:var(--muted);
margin-bottom:6px;
}
.catalog-meta span{
white-space:nowrap;
}
.catalog-price{
font-weight:800;
font-size:15px;
}
.catalog-actions{
display:flex;
gap:12px;
flex-wrap:wrap;
margin-top:16px;
}

.footer{
border-top:1px solid var(--border);
padding-top:12px;
padding-bottom:calc(56px + env(safe-area-inset-bottom));
background:rgba(255,255,255,.55);
backdrop-filter:saturate(1.15) blur(10px);
position:relative;
overflow:hidden;
margin-top:auto;
}
.footer::before{
content:"";
position:absolute;
left:0;
right:0;
top:-18vh;
bottom:0;
pointer-events:none;
background:linear-gradient(to top, rgba(var(--accentRgb), calc(.46 * var(--footerShade))) 0%, rgba(var(--accentRgb), 0) 74%);
transform:translate3d(0,0,0);
}
.footer-inner{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;align-items:center;position:relative}
.footer-left{white-space:nowrap}
.footer-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center;justify-content:flex-end;margin-left:auto}
.sharewrap{position:relative;display:inline-flex;align-items:center}
.sharebtn{
display:inline-flex;
align-items:center;
gap:8px;
border:1px solid var(--border);
background:rgba(255,255,255,.7);
border-radius:999px;
padding:9px 12px;
font:inherit;
color:var(--muted);
}
.sharebtn:hover{color:var(--text)}
.share-status{
position:absolute;
right:0;
top:calc(100% + 8px);
white-space:nowrap;
background:rgba(255,255,255,.86);
border:1px solid rgba(229,231,235,.9);
border-radius:999px;
padding:6px 10px;
box-shadow:var(--shadow);
opacity:0;
transform:translateY(-6px);
transition:opacity .16s ease, transform .16s ease;
pointer-events:none;
}
.share-status.on{opacity:1;transform:translateY(0)}

.modal-backdrop{
position:fixed;
inset:0;
background:rgba(0,0,0,.35);
backdrop-filter:blur(6px);
display:none;
align-items:center;
justify-content:center;
z-index:50;
padding:18px;
}
.modal-backdrop.open{display:flex}
.modal{
width:min(520px, 100%);
border:1px solid var(--border);
border-radius:22px;
background:rgba(255,255,255,.92);
box-shadow:var(--shadow2);
padding:16px;
}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.modal-head h3{margin:0;font-size:18px}
.modal-close{
border:1px solid var(--border);
background:#fff;
border-radius:12px;
padding:8px 10px;
font:inherit;
}
.modal-close:hover{box-shadow:var(--shadow)}
.modal .muted{margin:6px 0 0}
.modal-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.modal-status{min-height:18px;margin-top:10px}

.gallery-modal{
width:min(980px, 100%);
padding:12px;
position:relative;
}
.gallery-modal .modal-close{
position:absolute;
right:16px;
top:16px;
width:42px;
height:42px;
border-radius:999px;
padding:0;
display:grid;
place-items:center;
font-size:20px;
background:rgba(255,255,255,.96);
box-shadow:0 12px 32px rgba(0,0,0,.16);
}
.gallery-modal-body{
margin-top:10px;
border-radius:18px;
overflow:hidden;
border:1px solid rgba(229,231,235,.96);
background:#000;
}
.gallery-modal-body img{
display:block;
width:100%;
max-height:78vh;
object-fit:contain;
background:#000;
}

.car-modal{
width:min(980px, 100%);
padding:14px;
}
.car-modal-head h3{
margin:0;
font-size:18px;
}
.car-modal-info{
display:flex;
flex-wrap:wrap;
gap:10px 12px;
align-items:center;
margin-top:6px;
}
.car-price{
font-weight:900;
font-size:15px;
}
.car-meta{
display:flex;
flex-wrap:wrap;
gap:8px;
}
.chip{
display:inline-flex;
align-items:center;
padding:6px 10px;
border-radius:999px;
border:1px solid rgba(229,231,235,.95);
background:rgba(255,255,255,.82);
font-size:12px;
font-weight:800;
color:rgba(75,85,99,.92);
}

.car-gallery{
margin-top:12px;
display:flex;
flex-direction:column;
gap:10px;
}
.car-main{
position:relative;
border-radius:18px;
overflow:hidden;
border:1px solid rgba(229,231,235,.92);
background:#fff;
box-shadow:0 14px 38px rgba(0,0,0,.08);
}
.car-main img{
width:100%;
height:min(56vh, 520px);
object-fit:contain;
display:block;
background:#fff;
}
.car-nav{
position:absolute;
top:50%;
transform:translateY(-50%);
width:44px;
height:44px;
border-radius:14px;
border:1px solid rgba(229,231,235,.95);
background:rgba(255,255,255,.86);
font-size:26px;
line-height:1;
display:grid;
place-items:center;
box-shadow:0 10px 24px rgba(0,0,0,.10);
}
.car-nav.prev{left:10px}
.car-nav.next{right:10px}
.car-main.single .car-nav{display:none}

.car-thumbs{
display:flex;
gap:10px;
overflow:auto;
padding-bottom:4px;
}
.car-thumb-btn{
flex:0 0 auto;
width:110px;
height:78px;
border-radius:14px;
border:1px solid rgba(229,231,235,.95);
background:rgba(255,255,255,.92);
padding:0;
overflow:hidden;
box-shadow:0 10px 22px rgba(0,0,0,.06);
}
.car-thumb-btn img{
width:100%;
height:100%;
object-fit:cover;
display:block;
}
.car-thumb-btn.on{
border-color:rgba(var(--accentRgb),.35);
box-shadow:0 0 0 4px rgba(var(--accentRgb),.14),0 10px 22px rgba(0,0,0,.06);
}

.reveal{
opacity:0;
transform:translate3d(0,24px,0);
transition:opacity .55s cubic-bezier(.19,1,.22,1), transform .55s cubic-bezier(.19,1,.22,1);
}
.reveal.reveal-left{
transform:translate3d(-38px,0,0);
}
.reveal.reveal-right{
transform:translate3d(38px,0,0);
}
.reveal.in{
opacity:1;
transform:translate3d(0,0,0);
}
.reveal .section-head h2{
opacity:0;
transform:translate3d(0,18px,0);
transition:opacity .6s ease, transform .6s ease;
}
.reveal.in .section-head h2{
opacity:1;
transform:translate3d(0,0,0);
}
@media (prefers-reduced-motion: reduce){
.btn,.card,.reveal{transition:none}
.reveal{opacity:1;transform:none}
.reveal .section-head h2{opacity:1;transform:none}
}

@media (max-width: 940px){
.hero-grid,.grid-2{grid-template-columns:1fr}
h1{font-size:38px}
.steps{grid-template-columns:1fr}
.hero-card{aspect-ratio:16 / 10}
.about-card{justify-content:center}
.about-media{width:min(520px, 100%)}
.car-thumb-btn{width:96px;height:70px}
.info-row-inner{flex-direction:column}
.info-media{width:200px;height:150px}
}

@media (max-width: 700px){
.nav a{display:none}
.nav .pill{display:inline-flex}
.row{grid-template-columns:1fr}
.car-nav{width:40px;height:40px;border-radius:14px}
.car-main img{height:min(52vh, 460px)}
.info-content{align-items:flex-start;text-align:left}
}
