
/* === Site Theme v2 === */
:root{
  --bg:#0b1220;
  --surface:#0e172a;
  --panel:#111a2e;
  --panel-2:#0f1a30;
  --text:#e6eef8;
  --muted:#9fb0c6;
  --border:#23324a;
  --accent:#22c55e;
  --accent-2:#8ff0b5;
  --danger:#ef4444;
  --radius:16px;
  --radius-sm:12px;
  --space:12px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  color:var(--text);
  background:linear-gradient(180deg,var(--bg),#0a1222 40%, #09101e);
  font: 17px/1.55 ui-sans-serif, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Arial;
  letter-spacing:.2px;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent-2);text-decoration:none}
a:hover{text-decoration:underline}
.container{width:min(1120px,92vw);margin:0 auto}
.card{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:0 12px 28px rgba(4,10,20,.35)}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.9rem 1.1rem;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.06);background:linear-gradient(180deg,#2deb7a 0%, #1bb15d 100%);color:#04110a;font-weight:800;letter-spacing:.2px;box-shadow:0 10px 22px rgba(34,197,94,.25);transition:transform .08s ease}
.btn:hover{transform:translateY(-1px)}
.btn.ghost{background:rgba(255,255,255,.03);color:#e8f0fb;border-color:var(--border);box-shadow:none}
.tag{display:inline-block;padding:.35rem .7rem;border:1px solid var(--border);border-radius:999px;background:rgba(255,255,255,.02);color:#cfe0fb;font-size:.9rem}

/* Header */
header{position:sticky;top:0;z-index:40;background:rgba(9,15,26,.6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(35,50,74,.8)}
.nav{display:flex;align-items:center;justify-content:space-between;padding: calc(.55rem + env(safe-area-inset-top)) 0 .6rem}
.logo{display:flex;align-items:center;gap:.65rem;font-weight:900;letter-spacing:.25px}
.logo-mark{width:30px;height:30px;border-radius:10px;background:linear-gradient(180deg,#2deb7a,#1bb15d);box-shadow:0 8px 18px rgba(34,197,94,.35)}
nav ul{list-style:none;display:flex;gap:.4rem;padding:0;margin:0}
nav a{color:#eaf2ff;opacity:.98;padding:.55rem .85rem;border-radius:12px;display:block}
nav a:hover{background:rgba(255,255,255,.04);text-decoration:none}

/* Hero */
.hero{position:relative;isolation:isolate;min-height:64vh;display:grid;align-items:end;padding:8vh 0;background:radial-gradient(1200px 520px at 50% 0%, rgba(40,70,120,.35), transparent 70%), linear-gradient(180deg, rgba(10,15,25,.55), rgba(10,15,25,.35));overflow:hidden;border-bottom:1px solid var(--border)}
.hero-media{position:absolute;inset:0;z-index:-1}
.hero-media img, .hero-media video{width:100%;height:100%;object-fit:cover;filter:brightness(.6) contrast(1.05)}
.hero h1{font-size:clamp(28px,6vw,48px);line-height:1.08;margin:0 0 10px;font-weight:900}
.hero p{color:#cdd9eb;max-width:62ch;margin:.2rem 0 1.2rem}

/* Sections */
section{padding:44px 0}
h2{margin:0 0 14px;font-size: clamp(22px, 4vw, 30px)}
.muted{color:var(--muted)}

/* Gallery */
.gallery{display:grid;grid-template-columns: repeat(12, 1fr);gap:12px}
.gallery .card{grid-column:span 4}
.gallery figcaption{padding:10px 12px;color:#d1d5db}
@media (max-width: 1024px){
  .gallery .card{grid-column:span 6}
}
@media (max-width: 640px){
  .gallery .card{grid-column:span 12}
}

/* Video */
.video-cards{display:grid;grid-template-columns: repeat(12, 1fr);gap:12px}
.video-card{grid-column: span 6}
.video-thumb{position:relative}
.video-thumb::after{content:"▶";position:absolute;inset:auto 10px 10px auto;background:rgba(0,0,0,.45);border:1px solid var(--border);padding:.35rem .6rem;border-radius:12px;color:#fff}

/* Contact + Address */
.contact-grid{display:grid;grid-template-columns: 1.05fr .95fr;gap:18px}
.contact-card, .address-card{padding:16px}
.form-grid{display:grid;grid-template-columns: 1fr 1fr;gap:12px;margin-top:8px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1 / -1}
.input, textarea, input[type="text"], input[type="tel"], input[type="email"], input[type="url"]{
  width:100%;
  padding: .9rem 1rem;
  border-radius:12px;
  border:1px solid var(--border);
  background: #0c1529;
  color:#eaf2ff;
  outline:none;
  transition: box-shadow .15s ease, border-color .15s ease;
}
textarea{min-height:120px;resize:vertical}
input::placeholder, textarea::placeholder{color:#7f8ca3}
input:focus, textarea:focus{box-shadow:0 0 0 3px rgba(34,197,94,.22);border-color:#2a7b55}
.agree{display:flex;gap:.55rem;align-items:flex-start;color:#cdd6e1;margin-top:2px}
.agree input{transform:translateY(.25rem)}
.form-actions{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;margin-top:6px}
.map-shell{margin-top:.6rem;border:1px solid var(--border);border-radius:16px;overflow:hidden;background:#0b1220}
.map-shell img{width:100%;aspect-ratio:16/10;object-fit:cover}
.map-embed iframe{width:100%;height:360px;border:0}
@media (max-width: 1024px){
  .contact-grid{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
}

/* Footer */
footer{padding:calc(22px + env(safe-area-inset-bottom)) 0 22px;color:#b4c3d8;font-size:1rem;border-top:1px solid var(--border)}

/* Lightbox + Video modal */
.modal{position:fixed;inset:0;z-index:50;display:none;place-items:center;background:rgba(0,0,0,.4);-webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px)}
.modal.open{display:grid}
.modal-dialog{position:relative;width:min(1100px,94%);margin:auto;background:#000;border-radius:16px;overflow:hidden;border:1px solid var(--border)}
.modal img,.modal video{width:100%;height:100%;object-fit:contain;display:block}
.modal .close{z-index:3; position:absolute;top:8px;right:8px;background:#0b1220;border:1px solid var(--border);color:#fff;padding:.5rem .7rem;border-radius:12px;cursor:pointer}
.modal .nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:#0b1220;border:1px solid var(--border);color:#fff;padding:.6rem .8rem;border-radius:12px;cursor:pointer}
.modal .prev{left:8px}.modal .next{right:8px}

.richtext{white-space:pre-wrap;line-height:1.6;color:#dfe9f8}
.richtext p{margin:.5rem 0}

.table-wrap{width:100%;overflow:auto}
.table{width:100%;border-collapse:separate;border-spacing:0; border:1px solid var(--border); border-radius:12px; overflow:hidden; background:rgba(12,21,41,.4)}
.table thead th{background:rgba(255,255,255,.03); text-align:left; font-weight:700; padding:12px 12px; border-bottom:1px solid var(--border)}
.table td{padding:12px 12px;border-bottom:1px solid var(--border)}
.table tbody tr:hover{background:rgba(255,255,255,.03)}
.table tbody tr:last-child td{border-bottom:none}
.table-units td:nth-child(1){text-align:center; width:52px}
.table-units td:nth-child(3){white-space:nowrap}
.table-units td:nth-child(4){white-space:nowrap}


/* === Video modal sizing overrides === */
#videoModal .modal-dialog{
  width: min(960px, 92vw);
  aspect-ratio: 16 / 9;
  max-height: calc(100vh - 120px);
}
#videoModal video{
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #000;
}


/* Services block */
.services-grid{list-style:none;margin:12px 0 0;padding:0;display:grid;grid-template-columns:repeat(12,1fr);gap:12px}
.service-item{grid-column:span 6;display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 1px 0 rgba(0,0,0,.15) inset}
.service-ico{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:rgba(34,197,94,.15);color:#22c55e;font-weight:700;line-height:1}
.service-text{display:block}
@media (max-width: 800px){ .service-item{grid-column:span 12} }
