/* Bazentica — Front-end styles */

:root {
  --green-900: #0F2922;
  --green-800: #1F4A3D;
  --green-700: #2A5C4D;
  --green-50:  #EEF5F0;

  --gold-700: #9C7E36;
  --gold-500: #C8A24B;
  --gold-400: #D8B566;
  --gold-100: #F5EBCC;

  --cream-50:  #FBFAF6;
  --cream-100: #F5F1E6;
  --cream-200: #ECE5D2;

  --ink-900: #0E1419;
  --ink-800: #1B232B;
  --ink-700: #2A333C;
  --ink-600: #3D4854;
  --ink-500: #5B6772;
  --ink-400: #7B8693;
  --ink-300: #A4ADB6;
  --ink-200: #CBD2D8;
  --ink-100: #E6EAEE;

  --bg: #FFFFFF;
  --bg-soft: #F8F7F2;
  --fg: var(--ink-900);
  --rule: #E8E5DC;
  --rule-strong: #CFCABE;

  --primary: var(--green-800);
  --accent: var(--gold-500);

  --font-sans: "Plus Jakarta Sans", "Inter", ui-sans-serif, system-ui, sans-serif;
  --font-display: "Fraunces", Georgia, serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;

  --pad: clamp(20px, 4vw, 64px);
  --max: 1400px;
  --radius: 12px;

  --shadow-sm: 0 1px 2px rgba(15,41,34,0.05);
  --shadow-md: 0 4px 12px rgba(15,41,34,0.06), 0 2px 6px rgba(15,41,34,0.05);
  --shadow-lg: 0 24px 48px rgba(15,41,34,0.10), 0 8px 16px rgba(15,41,34,0.06);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { background: var(--bg); color: var(--fg); font-family: var(--font-sans); font-size: 16px; line-height: 1.55; -webkit-font-smoothing: antialiased; }
img, svg { display: block; max-width: 100%; }
button { font: inherit; color: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }
h1,h2,h3,h4 { letter-spacing: -0.015em; line-height: 1.1; margin: 0; }

.eyebrow {
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--primary); display: inline-flex; align-items: center; gap: 10px;
}
.eyebrow::before { content: ""; width: 22px; height: 1px; background: var(--accent); }
.mono { font-family: var(--font-mono); font-feature-settings: "tnum"; }

.container { max-width: var(--max); margin: 0 auto; padding-left: var(--pad); padding-right: var(--pad); }
.section { padding: clamp(64px, 8vw, 120px) 0; }
.section-tight { padding: clamp(40px, 5vw, 80px) 0; }

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
@media (max-width: 900px) { .grid-3, .grid-4 { grid-template-columns: 1fr 1fr; } .grid-2 { grid-template-columns: 1fr; } }
@media (max-width: 560px) { .grid-3, .grid-4 { grid-template-columns: 1fr; } }

.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px; border-radius: 10px; border: 1px solid transparent;
  font-size: 14.5px; font-weight: 600; white-space: nowrap;
  transition: all 200ms ease;
}
.btn-primary { background: var(--primary); color: #fff; }
.btn-primary:hover { background: var(--green-900); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn-gold { background: var(--accent); color: var(--ink-900); }
.btn-gold:hover { background: var(--gold-400); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn-ghost { background: transparent; color: var(--ink-900); border-color: var(--rule-strong); }
.btn-ghost:hover { background: var(--bg-soft); border-color: var(--ink-900); }
.btn-white { background: #fff; color: var(--ink-900); }
.btn-white:hover { background: #f4f4f4; }
.btn .arrow { transition: transform 220ms; }
.btn:hover .arrow { transform: translateX(3px); }

.banner { background: var(--ink-900); color: var(--cream-100); font-size: 13px; text-align: center; padding: 9px 16px; }

.nav { position: sticky; top: 0; z-index: 50; backdrop-filter: blur(14px) saturate(140%); -webkit-backdrop-filter: blur(14px) saturate(140%); background: rgba(255,255,255,0.86); border-bottom: 1px solid var(--rule); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; gap: 28px; height: 68px; }
.nav-brand { display: flex; align-items: center; gap: 10px; }
.nav-brand img { width: 38px; height: 38px; object-fit: contain; mix-blend-mode: multiply; }
.nav-brand-text { font-family: var(--font-display); font-size: 19px; font-weight: 600; letter-spacing: -0.01em; }
.nav-brand-text small { display: block; font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.22em; color: var(--ink-500); margin-top: 2px; text-transform: uppercase; font-weight: 500; }
.nav-links { display: flex; align-items: center; gap: 4px; }
@media (max-width: 980px) { .nav-links { display: none; } }
.nav-link { padding: 8px 14px; font-size: 14px; font-weight: 500; color: var(--ink-700); border-radius: 8px; transition: all 180ms; }
.nav-link:hover { color: var(--primary); background: var(--green-50); }
.nav-cta { display: flex; gap: 8px; align-items: center; }
.nav-iconbtn { width: 38px; height: 38px; border-radius: 10px; background: var(--bg-soft); border: 1px solid var(--rule); display: inline-flex; align-items: center; justify-content: center; color: var(--ink-700); transition: all 180ms; }
.nav-iconbtn:hover { background: var(--ink-900); color: #fff; border-color: var(--ink-900); }

.card { background: #fff; border: 1px solid var(--rule); border-radius: var(--radius); overflow: hidden; transition: all 220ms ease; }
.card:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); border-color: var(--ink-100); }

.photo { position: relative; overflow: hidden; background: var(--ink-100); }
.photo img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 600ms cubic-bezier(.2,.8,.2,1); }
.card:hover .photo img { transform: scale(1.04); }

.tag-pill { display: inline-flex; padding: 4px 10px; background: var(--green-50); color: var(--primary); border-radius: 999px; font-size: 11px; font-weight: 600; letter-spacing: 0.04em; }

.sec-head { margin-bottom: 48px; }
.sec-head .row { display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; align-items: end; }
@media (max-width: 800px) { .sec-head .row { grid-template-columns: 1fr; gap: 16px; } }
.sec-head h2 { font-family: var(--font-display); font-weight: 500; font-size: clamp(34px, 4.6vw, 56px); margin-top: 14px; text-wrap: balance; }
.sec-head h2 em { font-style: italic; color: var(--primary); font-weight: 500; }
.sec-head p { color: var(--ink-500); font-size: 16px; line-height: 1.6; max-width: 540px; }

/* Hero */
.hero { position: relative; min-height: 88vh; display: flex; flex-direction: column; justify-content: center; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; z-index: 0; }
.hero-bg img { width:100%; height:100%; object-fit: cover; }
.hero-bg-overlay { position:absolute; inset:0; background: linear-gradient(135deg, rgba(15,41,34,0.78) 0%, rgba(14,20,25,0.65) 50%, rgba(31,74,61,0.55) 100%); }
.hero-inner { position: relative; z-index: 2; padding: 110px 0 80px; color: #fff; }
.hero-badge { display: inline-flex; align-items: center; gap: 10px; background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.2); padding: 8px 16px; border-radius: 999px; font-size: 13px; backdrop-filter: blur(10px); margin-bottom: 28px; }
.hero-badge .dot { width:8px; height:8px; border-radius:50%; background:#25D366; box-shadow: 0 0 0 4px rgba(37,211,102,0.25); animation: hero-pulse 1.6s ease-in-out infinite; }
@keyframes hero-pulse { 50% { box-shadow: 0 0 0 8px rgba(37,211,102,0.05); } }
.hero-title { font-family: var(--font-display); font-size: clamp(44px, 6.4vw, 92px); font-weight: 500; line-height: 1.02; color: #fff; max-width: 1000px; text-wrap: balance; }
.hero-title em { font-style: italic; color: var(--gold-400); font-weight: 500; }
.hero-sub { font-size: clamp(16px, 1.6vw, 19px); line-height: 1.55; color: rgba(255,255,255,0.85); max-width: 620px; margin: 28px 0 36px; }
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-trust { margin-top: 56px; display: flex; flex-wrap: wrap; gap: 12px 20px; align-items: center; padding-top: 28px; border-top: 1px solid rgba(255,255,255,0.15); }
.trust-lbl { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255,255,255,0.55); margin-right: 8px; }
.trust-badge { font-size: 12px; font-weight: 600; padding: 5px 12px; border: 1px solid rgba(255,255,255,0.25); border-radius: 999px; color: rgba(255,255,255,0.9); }

/* Cat grid */
.cat-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.cat-grid > *:first-child { grid-column: span 2; grid-row: span 2; }
@media (max-width:980px) { .cat-grid { grid-template-columns: 1fr 1fr; } .cat-grid > *:first-child { grid-column: span 2; grid-row: auto; } }
@media (max-width:600px) { .cat-grid { grid-template-columns: 1fr; } .cat-grid > *:first-child { grid-column: auto; } }
.cat-card { display: flex; flex-direction: column; height: 100%; }
.cat-photo { aspect-ratio: 4/3; position: relative; }
.cat-card.feat .cat-photo { aspect-ratio: 5/4; }
.cat-num { position: absolute; top: 16px; left: 16px; background: rgba(255,255,255,0.92); color: var(--ink-900); }
.cat-meta { padding: 24px; flex: 1; display: flex; flex-direction: column; justify-content: space-between; gap: 24px; }
.cat-foot { display: flex; justify-content: space-between; align-items: center; padding-top: 16px; border-top: 1px solid var(--rule); }
.cat-arrow { font-size: 18px; color: var(--primary); transition: transform 220ms; }
.cat-card:hover .cat-arrow { transform: translateX(4px); }

/* Contact form */
.ct-grid { display:grid; grid-template-columns: 1.4fr 1fr; gap: 60px; align-items:start; }
@media (max-width: 900px) { .ct-grid { grid-template-columns:1fr; } }
.ct-row { display:grid; grid-template-columns: 1fr 1fr; gap:14px; }
@media (max-width: 600px) { .ct-row { grid-template-columns:1fr; } }
.ct-form .field { display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
.ct-form label { font-family:var(--font-mono); font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color: rgba(245,239,224,0.55); }
.ct-form input, .ct-form textarea { width:100%; background: rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.12); border-radius:8px; color:#fff; padding: 12px 14px; font-size:15px; font-family:inherit; outline:0; transition: all 200ms; }
.ct-form input:focus, .ct-form textarea:focus { border-color: var(--accent); background: rgba(255,255,255,0.06); }
.ct-form textarea { min-height: 84px; resize: vertical; }
.ct-aside { display:flex; flex-direction:column; gap: 24px; }
.ct-block { padding: 20px; background: rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.1); border-radius: var(--radius); }
.ct-block .lbl { font-family:var(--font-mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color: var(--accent); margin-bottom:10px; }
.ct-block ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:4px; font-size:14px; color: var(--cream-100); }
.ct-block a { color: var(--cream-100); }
.ct-block a:hover { color: var(--accent); }

/* Footer */
footer.foot { background: var(--ink-900); color: var(--ink-200); padding: 80px 0 30px; }
footer.foot a:hover { color: var(--accent); }
.ft-top { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr 1.1fr; gap: 40px; padding-bottom: 40px; border-bottom: 1px solid rgba(236,227,205,0.16); }
@media (max-width: 1080px) { .ft-top { grid-template-columns: 1fr 1fr 1fr; } .ft-brand { grid-column: span 3; } }
@media (max-width: 640px) { .ft-top { grid-template-columns: 1fr 1fr; } .ft-brand { grid-column: span 2; } }
.ft-h { font-family: var(--font-mono); font-size:10px; letter-spacing:0.22em; text-transform:uppercase; color: var(--accent); margin-bottom: 18px; }
.ft-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; font-size:14px; color: rgba(236,227,205,0.72); }
.ft-bot { margin-top:28px; display:flex; justify-content:space-between; gap: 24px; flex-wrap:wrap; font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color: rgba(236,227,205,0.45); }

/* Float WhatsApp */
.float-wa { position: fixed; bottom: 22px; left: 22px; z-index: 60; width: 54px; height: 54px; border-radius: 50%; background: #25D366; color: #fff; display: inline-flex; align-items: center; justify-content: center; box-shadow: 0 12px 32px rgba(37,211,102,0.42), 0 0 0 6px rgba(37,211,102,0.15); transition: transform 200ms; }
.float-wa:hover { transform: scale(1.08); }

::selection { background: var(--accent); color: var(--ink-900); }

/* Flash */
.flash { padding: 12px 16px; margin: 16px auto; max-width: var(--max); border-radius: 8px; font-size: 14px; font-weight: 500; }
.flash-success { background: #D1FAE5; color: #065F46; border: 1px solid #6EE7B7; }
.flash-error { background: #FEE2E2; color: #991B1B; border: 1px solid #FCA5A5; }
