:root{
  /* ===============================
     BRAND COLORS (FROM LOGO)
     =============================== */
  --brand-blue: #1F3460;
  --brand-gold: #C8B36B;
  --brand-gold-dark: #B89B45;
  --brand-gold-light: #E6D28A;

  /* ===============================
     LIGHT MODE ONLY (NO DARK MODE)
     =============================== */
  --blue: var(--brand-blue);
  --blue2: #162847; /* darker navy */
  --aqua: #3C5A8C;  /* muted accent */

  /* Background tints */
  --sky: #DCE6F4;
  --mint:#EDF2F8;

  /* Text */
  --ink:#0E1C36;
  --muted:#445A7A; /* AA on white */

  /* Surfaces */
  --paper:#FFFFFF;
  --paper2:#F6F8FC;

  /* Lines + shadows */
  --line: rgba(31,52,96,.14);
  --line-strong: rgba(31,52,96,.20);

  --shadow: 0 18px 50px rgba(14,28,54,.18);
  --shadow2: 0 10px 24px rgba(14,28,54,.12);

  /* UI chrome */
  --topbar-bg: rgba(255,255,255,.82);
  --footer-bg: rgba(255,255,255,.78);

  /* Gold accents */
  --gold: var(--brand-gold);
  --gold2: var(--brand-gold-dark);
  --gold3: var(--brand-gold-light);

  --badge-bg: rgba(200,179,107,.28);
  --badge-border: rgba(184,155,69,.55);
  --badge-text: var(--ink);

  /* Geometry */
  --radius: 18px;
  --radius2: 26px;

  --max: 1280px;
}

*{box-sizing:border-box}
html,body{height:100%}

body{
  margin:0;
  color:var(--ink);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  overflow-x:hidden;

  /* Keep background consistent across devices */
  background:
    radial-gradient(820px 520px at 18% 10%, color-mix(in srgb, var(--aqua) 35%, transparent), transparent 60%),
    radial-gradient(760px 520px at 85% 12%, color-mix(in srgb, var(--blue) 22%, transparent), transparent 60%),
    radial-gradient(900px 680px at 60% 92%, color-mix(in srgb, var(--mint) 95%, transparent), transparent 62%),
    linear-gradient(180deg, var(--paper) 0%, var(--sky) 55%, var(--paper) 100%);
}

/* subtle dots / texture */
body:before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  opacity:.18; /* reduced so it never “darkens” the page heavily */
  background-image:
    radial-gradient(circle at 10px 10px, color-mix(in srgb, var(--blue) 22%, transparent) 2px, transparent 3px),
    radial-gradient(circle at 30px 30px, color-mix(in srgb, var(--aqua) 20%, transparent) 2px, transparent 3px),
    radial-gradient(circle at 55px 18px, color-mix(in srgb, var(--ink) 12%, transparent) 1px, transparent 2px);
  background-size: 72px 72px;
  /* removed mix-blend-mode to prevent mobile browsers making it appear darker */
}

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

/* Global image scaling */
img{
  max-width:100%;
  height:auto;
  display:block;
}

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

.skip-link{
  position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{
  left:18px; top:18px; width:auto; height:auto; padding:12px 14px;
  background:#fff; border:2px solid rgba(11,36,71,.30);
  border-radius:14px; z-index:9999;
}

/* Top bar */
.topbar{
  position:sticky; top:0; z-index:1000;
  backdrop-filter: blur(10px);
  background: var(--topbar-bg);
  border-bottom:2px solid var(--line);
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  gap:14px;
  flex-wrap:nowrap;
}

.brand{
  display:flex; align-items:center; gap:12px;
  flex:0 0 auto;
  min-width:260px;
}

.site-logo{
  height:110px;
  width:auto;
  object-fit:contain;
  border-radius:12px;
  box-shadow: 0 8px 18px rgba(0,0,0,.10);
}

.brand h1{font-size:15px; margin:0; letter-spacing:.1px; line-height:1.1}
.brand p{margin:2px 0 0 0; font-size:12px; color:var(--muted)}
.brand a{
  color:var(--muted);
  text-decoration:underline;
  text-decoration-thickness:2px;
  text-underline-offset:3px;
}

.navlinks{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:nowrap;
  justify-content:flex-end;
}

.navlinks a{
  padding:10px 12px;
  border:2px solid transparent;
  border-radius:999px;
  color:var(--muted);
  font-size:13px;
  background: transparent;
  transition: .18s ease;
  white-space:nowrap;
}
.navlinks a:hover{
  background: color-mix(in srgb, var(--paper) 85%, transparent);
  border-color: var(--line);
  color: var(--ink);
}
.navlinks a.active{
  background: linear-gradient(135deg, color-mix(in srgb, var(--blue) 16%, transparent), color-mix(in srgb, var(--aqua) 18%, transparent));
  border-color: var(--line);
  color: var(--ink);
}

/* WhatsApp header button (legacy class kept) */
.wa-header{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  background: transparent;
  border: 2px solid var(--line);
}
.wa-header:hover{
  background: color-mix(in srgb, var(--paper) 85%, transparent);
}

.hamburger{
  display:none;
  border:2px solid var(--line-strong);
  background: color-mix(in srgb, var(--paper) 90%, transparent);
  color:var(--ink);
  border-radius:14px;
  padding:10px 12px;
  cursor:pointer;
  box-shadow: var(--shadow2);
}

.mobilepanel{
  display:none;
  border-top:2px solid var(--line);
  padding:10px 0 14px 0;
}
.mobilepanel a{
  display:block;
  padding:12px 12px;
  border-radius:16px;
  color:var(--muted);
}
.mobilepanel a:hover{
  background: color-mix(in srgb, var(--paper) 90%, transparent);
  color: var(--ink);
}
.mobilepanel.open{display:block}

/* Hero */
.hero{padding:58px 0 12px 0; position:relative}
.hero-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:18px;
  align-items:stretch;
}

.hero-card{
  background: linear-gradient(180deg, color-mix(in srgb, var(--paper) 94%, transparent), color-mix(in srgb, var(--paper2) 92%, transparent));
  border:2px solid var(--line);
  border-radius: var(--radius2);
  box-shadow: var(--shadow);
  overflow:hidden;
  position:relative;
}

/* decorative blobs (behind content) */
.hero-card:before{
  content:"";
  position:absolute;
  width:240px; height:240px;
  right:-80px; top:-80px;
  background: radial-gradient(circle at 40% 40%, color-mix(in srgb, var(--aqua) 55%, transparent), color-mix(in srgb, var(--aqua) 10%, transparent) 60%, transparent 72%);
  transform: rotate(12deg);
  z-index:0;
  pointer-events:none;
}
.hero-card:after{
  content:"";
  position:absolute;
  width:280px; height:170px;
  left:-100px; bottom:-80px;
  background: radial-gradient(circle at 50% 40%, color-mix(in srgb, var(--blue) 38%, transparent), color-mix(in srgb, var(--blue) 8%, transparent) 62%, transparent 75%);
  transform: rotate(-10deg);
  z-index:0;
  pointer-events:none;
}
.hero-card .pad{padding:28px; position:relative; z-index:2;}

/* =========================================================
   HERO LOGO (BIGGER + RESPONSIVE)
   ========================================================= */
.hero-logo{
  display:flex;
  justify-content:center;
  margin-bottom: 1rem;
}
.hero-logo img{
  width: min(360px, 80vw);  /* bigger on desktop, scales with viewport */
  height: auto;
}

/* Mobile sizing caps */
@media (max-width: 768px){
  .hero-logo img{ width: min(280px, 78vw); }
}
@media (max-width: 480px){
  .hero-logo img{ width: min(220px, 76vw); }
}

.kicker{
  display:inline-flex; gap:8px; align-items:center;
  padding:8px 12px;
  border-radius:999px;
  border:2px solid var(--line);
  background: color-mix(in srgb, var(--paper) 85%, transparent);
  color: var(--muted);
  font-size:12px;
}
.kicker .dot{
  width:10px; height:10px; border-radius:99px;
  background: linear-gradient(135deg, var(--blue), var(--aqua));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--blue) 14%, transparent);
}

.hero h2{
  margin:14px 0 10px 0;
  font-size:40px;
  letter-spacing:-.6px;
  line-height:1.05;
}
.hero p{
  margin:0;
  color: var(--muted);
  font-size:15px;
  line-height:1.65;
  max-width: 62ch;
}

.cta-row{display:flex; gap:10px; flex-wrap:wrap; margin-top:18px}

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:11px 14px;
  border-radius:16px;
  border:2px solid var(--line-strong);
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  color: var(--ink);
  font-size:13px;
  transition:.18s ease;
  box-shadow: 0 10px 20px var(--line);
}
.btn:hover{transform: translateY(-1px); background: color-mix(in srgb, var(--paper) 98%, transparent); border-color: var(--line-strong)}
.btn.primary{
  border-color: transparent;
  background: linear-gradient(135deg, var(--blue), var(--blue2), var(--aqua));
  color:#fff;
  box-shadow: 0 16px 36px rgba(47,128,237,.22);
}

.side-stack{display:flex; flex-direction:column; gap:14px}
.mini{
  border-radius: var(--radius2);
  border:2px solid var(--line);
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  box-shadow: var(--shadow2);
  padding:16px;
}
.mini h3{margin:0 0 6px 0; font-size:14px}
.mini p{margin:0; color:var(--muted); font-size:13px; line-height:1.55}

.badge{
  display:inline-flex;
  align-items:center;
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  border:2px solid var(--badge-border);
  background: var(--badge-bg);
  color: var(--badge-text);
  margin-top:10px;
  font-weight:700;
}

.section{padding:26px 0}
.section h2{margin:0 0 12px 0; font-size:22px; letter-spacing:-.2px}

/* Gold accent highlights */
.hero h2,
.section h2,
.card h3,
.mini h3{
  position:relative;
}

.hero h2:after,
.section h2:after{
  content:"";
  display:block;
  height:4px;
  width:72px;
  margin-top:10px;
  border-radius:999px;
  background: linear-gradient(90deg, var(--gold2), var(--gold), var(--gold3));
  opacity:.95;
}

.card h3:after,
.mini h3:after{
  content:"";
  display:block;
  height:3px;
  width:44px;
  margin-top:8px;
  border-radius:999px;
  background: linear-gradient(90deg, var(--gold2), var(--gold3));
  opacity:.9;
}

.grid3{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px}
.split{display:grid; grid-template-columns: 1fr 1fr; gap:14px}

.card{
  border-radius: var(--radius2);
  border:2px solid var(--line);
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  box-shadow: var(--shadow2);
  padding:18px;
}
.card h3{margin:0 0 6px 0; font-size:15px}
.card p{margin:0; color:var(--muted); font-size:13px; line-height:1.6}

.table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  overflow:hidden;
  border-radius:18px;
  border:2px solid var(--line);
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  box-shadow: var(--shadow2);
}
.table th,.table td{padding:12px 12px; border-bottom:1px solid var(--line); font-size:13px}
.table th{
  text-align:left;
  color: var(--ink);
  background: linear-gradient(180deg, color-mix(in srgb, var(--sky) 92%, transparent), color-mix(in srgb, var(--paper) 92%, transparent));
}
.table tr:last-child td{border-bottom:none}
.table td{color:var(--muted)}

.note{
  border-left: 5px solid color-mix(in srgb, var(--blue) 85%, transparent);
  padding:12px 14px;
  background: color-mix(in srgb, var(--sky) 92%, transparent);
  border-radius:16px;
  color: var(--muted);
  font-size:13px;
  line-height:1.6;
  box-shadow: var(--shadow2);
}

.form{display:grid; gap:10px}
.field{display:grid; gap:6px}
label{font-size:12px; color: color-mix(in srgb, var(--ink) 78%, transparent);}

input, textarea, select{
  width:100%;
  padding:12px 12px;
  border-radius:16px;
  border:2px solid var(--line);
  background: color-mix(in srgb, var(--paper) 95%, transparent);
  color: var(--ink);
  outline:none;
}
textarea{min-height:120px; resize:vertical}
input:focus, textarea:focus, select:focus{
  border-color: color-mix(in srgb, var(--blue) 55%, transparent);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--blue) 14%, transparent);
}

/* Gallery */
.gallery{
  display:grid;
  gap:12px;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  align-items:stretch;
}

/* Category cards (Gallery -> Categories) */
.gitem{
  border-radius:18px;
  border:2px dashed var(--line-strong);
  background: color-mix(in srgb, var(--paper) 90%, transparent);
  overflow:hidden;
  position:relative;
  box-shadow: var(--shadow2);

  max-width:320px;
  margin:0 auto;
  aspect-ratio: 4 / 3;
  min-height: 180px;
}
.gitem::before{ content:""; display:block; padding-top:75%; }

.gitem img{
  width:100%;
  height:100%;
  object-fit:cover;
  position:absolute;
  inset:0;
}

.gitem .cap{
  position:absolute;
  left:12px;
  right:12px;
  bottom:12px;
  padding:8px 10px;
  border-radius:14px;
  border:2px solid var(--line);
  background: color-mix(in srgb, var(--paper) 86%, transparent);
  font-size:12px;
  color: var(--ink);
  text-align:center;
}

@media (max-width: 760px){
  .gallery{ grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); }
  .gitem{ max-width:100%; aspect-ratio: 16 / 10; min-height: 160px; }
  .gitem::before{ padding-top:62.5%; }
}

@media (max-width: 520px){
  .gitem{ aspect-ratio: 16 / 9; min-height: 150px; }
  .gitem::before{ padding-top:56.25%; }
}

/* Map */
.map{
  width:100%;
  min-height:320px;
  border:2px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  box-shadow: var(--shadow2);
}

/* Footer */
.footer{
  padding:26px 0;
  border-top:2px solid var(--line);
  background: var(--footer-bg);
  margin-top:24px;
}
.footergrid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:14px;
  align-items:start;
}
.footer p,.footer a{color:var(--muted); font-size:13px; line-height:1.6}
.smalllinks{display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end}
.smalllinks a{
  padding:8px 10px;
  border-radius:999px;
  border:2px solid var(--line);
  background: color-mix(in srgb, var(--paper) 90%, transparent);
}
.smalllinks a:hover{border-color: var(--line-strong); background: rgba(255,255,255,.98)}

.designed-by{
  margin-left:8px;
  white-space:nowrap;
}
.designed-by a{font-weight:800; color:var(--blue2); text-decoration:underline; text-underline-offset:3px}

/* Responsive */
@media (max-width: 1100px){
  .navlinks{gap:8px}
  .navlinks a{font-size:12px; padding:8px 10px}
}
@media (max-width: 920px){
  .hero-grid{grid-template-columns: 1fr}
  .grid3{grid-template-columns: 1fr}
  .split{grid-template-columns: 1fr}
  .footergrid{grid-template-columns: 1fr}
  .smalllinks{justify-content:flex-start}
}
@media (max-width: 760px){
  .navlinks{display:none}
  .hamburger{display:inline-flex}
  .site-logo{height:40px}
  .hero h2{font-size:34px}
  .gitem{grid-column: auto;}

  /* IMPORTANT: remove overlay texture on mobile to avoid “dark” look */
  body:before{ display:none; }
}
@media (max-width: 520px){
  .gitem{grid-column: auto;}
}

/* WhatsApp button = image only */
.wa-image-btn{
  display:inline-block;
  line-height:0;
}
.wa-image-btn img{
  display:block;
  height:62px;
  width:auto;
  border:0;
}
@media (max-width:760px){
  .wa-image-btn img{ height:34px; }
}

/* Category gallery thumbnails */
.thumb-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap:12px;
}
.thumb{
  grid-column: span 4;
  border-radius:18px;
  overflow:hidden;
  border:2px solid var(--line);
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  box-shadow: var(--shadow2);
  cursor:pointer;
}
.thumb img{
  width:100%;
  height:220px;
  object-fit:cover;
  display:block;
}
.thumb .tcap{
  padding:10px 12px;
  font-size:12px;
  color: var(--ink);
  border-top:1px solid var(--line);
  background: color-mix(in srgb, var(--paper) 86%, transparent);
}

/* Lightbox */
.lightbox{
  position:fixed;
  inset:0;
  z-index:9999;
  display:none;
  align-items:center;
  justify-content:center;
  background: rgba(0,0,0,.70);
  padding:18px;
}
.lightbox.open{ display:flex; }
.lightbox-inner{
  max-width:min(1100px, 96vw);
  max-height:92vh;
  position:relative;
}
.lightbox-inner img{
  max-width:100%;
  max-height:92vh;
  display:block;
  border-radius:16px;
  box-shadow: 0 24px 70px rgba(0,0,0,.35);
}
.lightbox-close{
  position:absolute;
  top:-14px;
  right:-14px;
  width:40px;
  height:40px;
  border-radius:999px;
  border:0;
  cursor:pointer;
  font-size:18px;
  font-weight:800;
  background:#fff;
  box-shadow: 0 14px 40px rgba(0,0,0,.25);
}

/* Responsive (thumbnails) */
@media (max-width: 760px){
  .thumb{ grid-column: span 6; }
  .thumb img{ height:190px; }
}
@media (max-width: 520px){
  .thumb{ grid-column: span 12; }
  .thumb img{ height:200px; }
}

/* Background compatibility fallback (older browsers without color-mix) */
@supports not (background: color-mix(in srgb, white 50%, transparent)){
  body{
    background:
      radial-gradient(820px 520px at 18% 10%, rgba(60,90,140,.35), transparent 60%),
      radial-gradient(760px 520px at 85% 12%, rgba(31,52,96,.22), transparent 60%),
      radial-gradient(900px 680px at 60% 92%, rgba(237,242,248,.95), transparent 62%),
      linear-gradient(180deg, var(--paper) 0%, var(--sky) 55%, var(--paper) 100%);
  }
}

/* TikTok: force mobile scaling */
.tiktok-grid,
.tiktok-videos,
.videos-grid,
.video-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.tiktok-embed,
.tiktok-embed iframe,
iframe[src*="tiktok.com"],
blockquote.tiktok-embed {
  max-width: 100% !important;
  width: 100% !important;
}

iframe[src*="tiktok.com"] {
  height: auto !important;
  aspect-ratio: 9 / 16;
  border: 0;
  display: block;
}

.tiktok-grid img,
.tiktok-videos img,
.video-grid img,
.videos-grid img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

@media (max-width: 760px) {
  .tiktok-grid,
  .tiktok-videos,
  .videos-grid,
  .video-grid {
    grid-template-columns: 1fr;
  }
}
