/* ============================================================
   CAFTM — Brand Theme  (based on new logo)
   Navy #001947 · Royal Blue #1656D6 · Teal Green #13B094
   ============================================================ */
:root{
  --navy:#001947;
  --navy-800:#0A2352;
  --royal:#1656D6;      /* primary action */
  --royal-700:#0E3E9E;
  --blue-600:#1D61B9;
  --teal:#13B094;       /* accent */
  --teal-400:#1DC79A;
  --grad:linear-gradient(135deg,#1656D6 0%,#13B094 100%);
  --grad-soft:linear-gradient(135deg,#eef4ff 0%,#e9fbf5 100%);

  --ink:#0e1b2e;        /* headings */
  --body:#44526a;       /* body text */
  --muted:#7a8aa3;
  --white:#ffffff;
  --bg:#f6f9fe;
  --surface:#ffffff;
  --line:#e4ebf5;

  --wa:#25D366;
  --shadow:0 10px 30px -12px rgba(9,32,71,.18);
  --shadow-lg:0 24px 60px -22px rgba(9,32,71,.30);
  --radius:14px; --radius-lg:22px; --maxw:1160px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:'Inter',system-ui,-apple-system,sans-serif;
  color:var(--body);background:var(--bg);line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Poppins',sans-serif;color:var(--ink);line-height:1.25;margin:0 0 .5em}
a{color:var(--royal);text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.text-grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* -------- Buttons -------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-family:'Poppins',sans-serif;
  padding:12px 24px;border-radius:12px;border:0;cursor:pointer;font-size:.95rem;transition:.2s;text-align:center}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 8px 22px -8px rgba(22,86,214,.55)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 30px -8px rgba(22,86,214,.6)}
.btn-outline{background:#fff;color:var(--navy);border:1.5px solid var(--line)}
.btn-outline:hover{border-color:var(--royal);color:var(--royal)}
.btn-wa{background:var(--wa);color:#fff}
.btn-sm{padding:8px 16px;font-size:.85rem}

/* -------- Header -------- */
header.site{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.9);
  backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px}
.logo img{height:42px;width:auto}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{color:var(--navy);font-weight:500;padding:8px 12px;border-radius:8px;font-size:.92rem;transition:.15s}
.nav-links a:hover,.nav-links a.active{color:var(--royal);background:#eef4ff}
.nav-links a.cta{background:var(--grad);color:#fff!important;padding:9px 18px}
.nav-links a.cta:hover{opacity:.92}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.hamburger span{width:24px;height:2.5px;background:var(--navy);border-radius:3px;transition:.3s}
.mobile-nav{display:none;flex-direction:column;background:#fff;border-bottom:1px solid var(--line);padding:8px 20px}
.mobile-nav a{padding:12px 8px;color:var(--navy);border-bottom:1px solid var(--line);font-weight:500}
.mobile-nav.open{display:flex}

/* -------- Quick links strip -------- */
.quick-strip{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;padding:16px 0}
.quick-btn{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);
  padding:8px 16px;border-radius:30px;font-size:.85rem;font-weight:600;color:var(--navy);box-shadow:var(--shadow)}
.quick-btn:hover{border-color:var(--teal);color:var(--teal)}
.quick-btn svg{width:16px;height:16px;fill:var(--royal)}

/* -------- Hero -------- */
.hero{position:relative;overflow:hidden;background:var(--navy);color:#fff;border-radius:0 0 32px 32px}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(900px 400px at 15% -10%,rgba(22,86,214,.55),transparent 60%),
  radial-gradient(700px 400px at 90% 20%,rgba(19,176,148,.45),transparent 60%)}
.hero-in{position:relative;padding:72px 0 84px;max-width:760px}
.hero .badge{display:inline-block;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  padding:7px 16px;border-radius:30px;font-size:.82rem;font-weight:600;margin-bottom:22px}
.hero h1{color:#fff;font-size:clamp(2rem,5vw,3.2rem);font-weight:800}
.hero h1 span{background:linear-gradient(90deg,#7fd7ff,#37e0b8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p{color:#c9d6ea;font-size:1.1rem;max-width:620px;margin:18px 0 28px}
.hero .btn-group{display:flex;gap:14px;flex-wrap:wrap}
.hero .btn-outline{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.25)}

/* -------- Stats -------- */
.stats{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:26px;margin:-44px auto 0;max-width:var(--maxw);position:relative}
.stat h3{font-size:2rem;margin:0;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat p{margin:2px 0 0;font-size:.85rem;color:var(--muted);font-weight:600}
.stat{text-align:center;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}

/* -------- Sections -------- */
.section{padding:64px 0}
.section-head{text-align:center;max-width:640px;margin:0 auto 42px}
.section-head .eyebrow{color:var(--teal);font-weight:700;text-transform:uppercase;letter-spacing:1px;font-size:.8rem}
.section-head h2{font-size:clamp(1.6rem,3.5vw,2.3rem);margin:.3em 0}
.section-head p{color:var(--muted)}

/* -------- Cards grid -------- */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;transition:.22s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.card .icon{width:52px;height:52px;border-radius:13px;background:var(--grad-soft);display:grid;place-items:center;
  font-size:1.5rem;margin-bottom:14px}
.card h3{font-size:1.1rem;margin:0 0 8px}
.card p{font-size:.92rem;color:var(--body);margin:0 0 14px;flex:1}
.card .card-link{color:var(--royal);font-weight:600;font-size:.9rem}

/* -------- Product card -------- */
.p-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.22s;display:flex;flex-direction:column}
.p-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.p-thumb{aspect-ratio:16/10;background:var(--grad-soft);display:grid;place-items:center;font-size:2.4rem;position:relative}
.p-badge{position:absolute;top:10px;left:10px;background:var(--teal);color:#fff;font-size:.7rem;font-weight:700;padding:4px 10px;border-radius:20px}
.p-body{padding:16px;display:flex;flex-direction:column;flex:1}
.p-body h3{font-size:1rem;margin:0 0 6px}
.p-cat{font-size:.72rem;color:var(--teal);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.p-price{display:flex;align-items:baseline;gap:8px;margin:10px 0 12px}
.p-price .now{font-size:1.25rem;font-weight:800;color:var(--navy)}
.p-price .was{font-size:.9rem;color:var(--muted);text-decoration:line-through}
.p-price .free{color:var(--teal);font-weight:800}

/* -------- Category pills -------- */
.cat-pills{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:30px}
.cat-pill{background:#fff;border:1px solid var(--line);padding:8px 18px;border-radius:30px;font-weight:600;font-size:.88rem;color:var(--navy)}
.cat-pill:hover,.cat-pill.active{background:var(--grad);color:#fff;border-color:transparent}

/* -------- Testimonials -------- */
.t-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.t-card .stars{color:#f6b100;margin-bottom:10px}
.t-card p{font-style:italic;color:var(--ink)}
.t-who{display:flex;align-items:center;gap:12px;margin-top:16px}
.t-avatar{width:44px;height:44px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-weight:700}
.t-who b{color:var(--navy);display:block;font-size:.95rem}
.t-who small{color:var(--muted)}

/* -------- FAQ -------- */
.faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden}
.faq-q{padding:16px 20px;font-weight:600;color:var(--navy);cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:'Poppins'}
.faq-a{padding:0 20px;max-height:0;overflow:hidden;transition:.3s;color:var(--body)}
.faq-item.open .faq-a{padding:0 20px 18px;max-height:400px}
.faq-item.open .faq-q .plus{transform:rotate(45deg)}
.faq-q .plus{transition:.3s;color:var(--royal);font-size:1.4rem}

/* -------- CTA banner -------- */
.cta-banner{background:var(--grad);border-radius:var(--radius-lg);color:#fff;text-align:center;padding:48px 24px;margin:0 auto}
.cta-banner h2{color:#fff}
.cta-banner .btn-outline{background:rgba(255,255,255,.15);color:#fff;border-color:rgba(255,255,255,.35)}
.cta-banner .btn-primary{background:#fff;color:var(--royal)}

/* -------- Newsletter -------- */
.news-form{display:flex;gap:10px;max-width:460px;margin:16px auto 0}
.news-form input{flex:1;padding:12px 16px;border:1px solid var(--line);border-radius:10px;font-size:.95rem}

/* -------- Detail page -------- */
.detail-hero{background:var(--navy);color:#fff;padding:44px 0;border-radius:0 0 28px 28px}
.detail-hero h1{color:#fff}
.breadcrumb{font-size:.85rem;color:var(--muted);margin-bottom:18px}
.breadcrumb a{color:var(--royal)}
.prose{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px}
.prose h2,.prose h3{color:var(--navy)}
.info-box{background:var(--grad-soft);border:1px solid #dbe8ff;border-radius:12px;padding:18px;margin:16px 0}
.pill{display:inline-block;background:#eef4ff;color:var(--royal);padding:5px 12px;border-radius:20px;font-size:.8rem;font-weight:600;margin:3px}

/* -------- Forms -------- */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-weight:600;color:var(--navy);font-size:.9rem;margin-bottom:6px}
.form-group input,.form-group textarea,.form-group select{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-size:.95rem;font-family:inherit}
.form-group input:focus,.form-group textarea:focus{outline:0;border-color:var(--royal);box-shadow:0 0 0 3px rgba(22,86,214,.12)}
.alert{padding:14px 18px;border-radius:10px;margin-bottom:16px;font-weight:500}
.alert-success{background:#e8faf3;color:#0a6b4d;border:1px solid #bdeeda}
.alert-error{background:#fdecec;color:#a12626;border:1px solid #f5c6c6}

/* -------- Footer -------- */
footer.site{background:var(--navy);color:#c9d6ea;padding:54px 0 24px;margin-top:60px}
footer.site h4{color:#fff;font-size:1rem;margin-bottom:14px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:36px}
footer.site a{color:#c9d6ea;display:block;padding:4px 0;font-size:.9rem}
footer.site a:hover{color:var(--teal-400)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:30px;padding-top:18px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.85rem;color:#8ea3c2}

/* -------- Floating WhatsApp -------- */
.wa-float{position:fixed;bottom:22px;right:22px;width:56px;height:56px;background:var(--wa);border-radius:50%;
  display:grid;place-items:center;box-shadow:0 8px 24px -6px rgba(37,211,102,.6);z-index:90}
.wa-float svg{width:28px;height:28px;fill:#fff}

/* -------- Responsive -------- */
@media(max-width:960px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:0}
}
@media(max-width:640px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .grid-4,.grid-3{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr;margin-top:-30px}
  .foot-grid{grid-template-columns:1fr}
  .news-form{flex-direction:column}
  .hero-in{padding:52px 0 64px}
}
