/* Font Awesome loaded locally via css/all.min.css */

/* ========== Root theme & layout base ========== */
:root{
  --brand-blue:#0d47a1;
  --brand-blue-dark:#103a8b;
  --text:#222;
  --muted:#555;
  --bg:#f9f9f9;
  --card:#fff;
  --card-ghost:#f9f9f9;
  --border:#e5e7eb;
  --danger:#c62828;

  /* Refund/notes */
  --warn-bg:#fff7e6;
  --warn-bd:#ffd99a;
  --warn-tx:#7a4c00;

  /* Social */
  --header-h:64px;
}

/* Page baseline + sticky footer layout */
html,body{height:100%;margin:0;overflow-x:hidden;}
body{
  min-height:100dvh;
  display:flex;flex-direction:column;
  background:var(--bg);
  font-family:Arial, sans-serif;
  overflow-y:auto;
}
main{flex:1 0 auto;}

/* Font fallback for brands (extra safety) */
@font-face { font-family: "Font Awesome 6 Brands"; font-style: normal; font-weight: 400; font-display: swap; src: url("https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.0/webfonts/fa-brands-400.woff2") format("woff2"); }

/* ========== ABOUT ========== */
.about-wrap{padding:20px;background:var(--card-ghost);}
.about-title{
  text-align:center;font-size:26px;margin-bottom:25px;
  font-weight:700;color:var(--brand-blue);
}
.about-cards{
  display:grid;grid-template-columns:1fr;gap:18px;
  max-width:1100px;margin:auto;
}
@media (min-width:1200px){
  .about-cards{grid-template-columns:repeat(2,1fr);}
}
.about-card{
  background:#fff;border-radius:16px;padding:20px;
  box-shadow:0 6px 18px rgba(0,0,0,.08);
  transition:transform .3s, box-shadow .3s;
}
.about-card:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.15);}
.about-card h3{
  margin-top:0;font-size:20px;font-weight:700;color:#103a8b;
  display:flex;align-items:center;gap:8px;
}
.about-card p,.about-card ul{margin:10px 0 0;line-height:1.6;color:#333;font-size:15px;}
.about-card ul{padding-left:18px;}
.about-icon{font-size:22px;}

/* ========== CONTACT ========== */
.contact-wrap{padding:20px;background:var(--card-ghost);min-height:auto;}
.contact-title{text-align:center;font-size:24px;margin-bottom:20px;color:var(--brand-blue);}
.contact-cards{display:flex;flex-direction:column;gap:18px;max-width:960px;margin:auto;}
.contact-card{
  background:#fff;border-radius:16px;padding:18px 20px;
  box-shadow:0 6px 18px rgba(0,0,0,.08);
  transition:transform .3s, box-shadow .3s;
}
.contact-card:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.15);}
.contact-card h3{
  margin-top:0;font-size:20px;color:#103a8b;display:flex;align-items:center;gap:8px;
}
.contact-card p,.contact-card a{
  margin:8px 0 0;line-height:1.6;color:#333;text-decoration:none;font-size:15px;
}
.contact-card a:hover{color:var(--brand-blue);text-decoration:underline;}
/* WhatsApp big button */
.contact-whatsapp-btn{
  display:inline-flex;align-items:center;gap:10px;background:#25D366;color:#fff;
  padding:14px 20px;border-radius:50px;font-weight:bold;font-size:16px;
  text-decoration:none;transition:.3s;margin:28px auto 0;justify-content:center;
}
.contact-whatsapp-btn img{width:28px;height:28px;}
.contact-whatsapp-btn:hover{background:#1ebe5d;transform:scale(1.05);}
.contact-whatsapp-btn .fa-whatsapp{font-size:22px;line-height:1;display:inline-block;vertical-align:middle;}
@media (max-width:599px){
  .contact-whatsapp-btn .fa-whatsapp{font-size:45px;}
}

/* ========== DISCLAIMER ========== */
.disc-wrap{padding:20px;background:transparent;}
.disc-title{
  text-align:center;font-size:24px;margin-bottom:20px;color:var(--danger);
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.disc-cards{
  display:flex;flex-direction:column;gap:18px;max-width:960px;margin:auto;
  overflow-y:auto;max-height:85vh;padding-right:10px;
}
.disc-card{
  background:#fff;border-left:6px solid var(--danger);
  border-radius:12px;padding:18px 20px;
  box-shadow:0 6px 18px rgba(0,0,0,.08);
  transition:transform .3s, box-shadow .3s;flex:1 1 100%;
}
.disc-card:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.15);}
.disc-card h3{
  margin:0 0 8px;font-size:18px;color:#b71c1c;
  display:flex;align-items:center;gap:8px;
}
.disc-card p{margin:0 0 8px;line-height:1.6;color:#333;}
.disc-card ul{margin:0;line-height:1.6;color:#333;padding-left:20px;}

/* ========== FAQ ========== */
.faq-wrap{max-width:880px;margin:auto;padding:20px;}

/* ========== PRIVACY ========== */
.doc{max-width:960px;margin:auto;background:transparent;border-radius:0;padding:0;box-shadow:none}
.doc-title{
  text-align:center;font-size:26px;margin:0 0 10px;color:var(--brand-blue);
  display:flex;align-items:center;justify-content:center;gap:8px;font-weight:700;
}
.doc .muted{color:#64748b;font-size:13px;margin:0 0 12px;text-align:center}
.doc .last-updated{margin:0 0 12px;text-align:right;color:#64748b;font-size:12px;background:#eef5ff;display:inline-block;padding:6px 10px;border-radius:999px}
.doc .hr{height:1px;background:#e5e7eb;margin:16px 0 12px}
.doc h2{margin:16px 0 8px;font-size:18px;color:#103a8b}
.doc ul{margin:8px 0 0 18px;line-height:1.6;color:#333}
.doc p{line-height:1.7;color:#333}
/* Section cards for privacy */
.p-card{background:#fff;border:1px solid #e7efff;border-left:6px solid #0A58CA;border-radius:12px;padding:16px 16px;margin:14px 0;box-shadow:0 6px 14px rgba(0,0,0,.06);transition:transform .3s, box-shadow .3s}
.p-card:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.15)}
.p-card h2{margin:0 0 8px;color:#0A58CA}
/* Quick TOC */
.privacy-toc{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 6px}
.privacy-toc a{display:inline-block;padding:6px 10px;border-radius:999px;background:#f7faff;border:1px dashed #d3e1ff;color:#0A58CA;text-decoration:none;font-size:13px}
.privacy-toc a:hover{background:#eef5ff}
@media (min-width:900px){
  .doc{padding:24px 26px;border-radius:18px}
  .doc h2{font-size:19px}
}

/* Print-friendly */
@media print{
  body{background:#fff}
  .doc{box-shadow:none;border:1px solid #ddd}
  .privacy-toc{display:none}
}
.faq-title{
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-size:26px;margin-bottom:20px;color:var(--brand-blue);font-weight:700;text-align:center;
}
.faq-title i{color:var(--brand-blue);font-size:24px;line-height:1;}
.faq-item{margin-bottom:12px;}
.faq-question{
  width:100%;background:#e3f2fd;color:#103a8b;font-size:16px;font-weight:600;
  padding:16px 14px 16px 12px;border-radius:12px;text-align:left;border:none;outline:none;
  cursor:pointer;display:flex;justify-content:flex-start;align-items:center;gap:6px;transition:background .25s;
}
.faq-question i{color:var(--brand-blue);font-size:18px;margin-right:2px;}
.faq-question:hover{background:#d0e4fa;}
.faq-arrow{font-size:0;transition:transform .25s;margin-left:auto;display:inline-block;}
.faq-arrow::before{content:'▼';font-size:16px;display:inline-block;transition:transform .25s;}
.faq-answer{
  height:0;overflow:hidden;transition:height .28s ease, padding .2s ease;
  padding:0 16px;color:#333;line-height:1.6;
}
.faq-answer::before{
  content:'A):';display:block;font-weight:700;color:var(--brand-blue);margin:8px 0 4px;
}
.faq-answer.open{padding:12px 16px;/* height set via JS for smooth animation */}
.faq-question.active .faq-arrow::before{transform:rotate(180deg);}
.warn{color:#b45309;font-weight:700;}
@media (max-width:600px){
  .faq-wrap{max-width:100%;padding:16px;}
  .faq-question{padding:14px 14px;gap:10px;}
}

/* ========== SOCIAL (Connect With Us) ========== */

.social-wrap{margin-top:calc(var(--header-h) + 16px);padding:20px;}
.social-title{text-align:center;font-size:24px;margin:0 0 48px;color:var(--brand-blue);font-weight:700;}
.icon i{font-size:28px;line-height:1;display:inline-block;}
.connect-card .icon{
  width:64px;height:64px;border-radius:50%;background-color:currentColor;
  display:flex;align-items:center;justify-content:center;margin:0 auto 10px;
}
.connect-card .name{font-weight:700;text-align:center;}
.connect-card .cta{color:var(--brand-blue);font-size:14px;text-align:center;}
.connect-card{
  display:block;text-decoration:none;color:inherit;padding:4px 2px;border-radius:12px;outline:none;
}
.connect-card:focus-visible{box-shadow:0 0 0 3px rgba(13,71,161,.25);}
.connect-grid{
  max-width:960px;margin:0 auto;padding-inline:12px;scroll-behavior:smooth;scrollbar-width:thin;
}
.connect-grid::-webkit-scrollbar{height:8px;}
.connect-grid::-webkit-scrollbar-thumb{background:rgba(0,0,0,.18);border-radius:8px;}
/* Phones */
@media (max-width:599px){
  .social-title{margin-bottom:24px;}
  .connect-grid{
    display:flex;flex-flow:row nowrap;gap:18px;overflow-x:auto;padding-bottom:8px;
    -webkit-overflow-scrolling:touch;touch-action:pan-x;scroll-snap-type:x mandatory;margin-top:22px;
  }
  .connect-card{flex:0 0 auto;min-width:140px;scroll-snap-align:start;text-align:center;}
  .connect-card .icon{width:56px;height:56px;margin-bottom:13px;}
  .icon i{font-size:24px;}
}
/* Tablets */
@media (min-width:600px) and (max-width:899px){
  .social-title{margin-bottom:32px;}
  .connect-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;overflow:visible;scroll-snap-type:none;margin-top:28px;}
}
/* Desktop+ */
@media (min-width:900px){
  .connect-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;overflow:visible;scroll-snap-type:none;margin-top:40px;}
}

/* SOCIAL glyph visibility */
.connect-card .icon i,
.connect-card .icon svg {
  color: #fff !important;      /* font icons */
  fill: #fff !important;       /* svg icons */
}

/* Hover & motion */
@media (hover:hover) and (pointer:fine){
  .connect-card{transition:transform .25s, box-shadow .25s;}
  .connect-card .icon{transition:transform .25s, box-shadow .25s;box-shadow:0 0 0 rgba(0,0,0,0);}
  .connect-card:hover{transform:translateY(-4px);box-shadow:0 10px 22px rgba(0,0,0,.12);}
  .connect-card:hover .icon{transform:scale(1.08);box-shadow:0 6px 14px rgba(0,0,0,.18);}
  .connect-card:hover .cta{text-decoration:underline;}
}
.connect-card:active .icon{transform:scale(.96);}
@media (prefers-reduced-motion:reduce){
  .connect-card,.connect-card .icon{transition:none !important;}
}

/* ========== TERMS ========== */
.terms-wrap{padding:20px;background:var(--card-ghost);}
.terms-title{text-align:center;font-size:24px;margin-bottom:20px;color:var(--brand-blue);}
.terms-cards{
  display:flex;flex-direction:column;gap:18px;max-width:960px;margin:auto;padding-right:10px;
}
.terms-card{
  background:#fff;border-left:6px solid var(--brand-blue);
  border-radius:12px;padding:18px 20px;
  box-shadow:0 6px 18px rgba(0,0,0,.08);
  transition:transform .3s, box-shadow .3s;
}
.terms-card:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.15);}
.terms-card h3{
  margin:0 0 8px;font-size:18px;color:var(--brand-blue-dark);
  display:flex;align-items:center;gap:8px;
}
.terms-card p,.terms-card ul{margin:0;line-height:1.6;color:#333;}
.terms-card ul{margin-top:8px;padding-left:18px;}

/* ========== FOOTER (global) ========== */
.footer{
  width:100%;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;
  column-gap:12px;row-gap:8px;text-align:center;padding:14px 12px 28px;margin-top:24px;
  border-top:1px solid #e8efff;font-size:14px;color:#64748b;
}
.footer a{color:var(--brand-blue);text-decoration:none;padding:6px 10px;border-radius:8px;transition:background .18s ease, box-shadow .18s ease}
.footer a:hover,.footer a:focus-visible{background:rgba(13,71,161,.08);outline:none;box-shadow:0 0 0 2px rgba(13,71,161,.12)}
.footer .sep{opacity:.45;margin:0 2px;}
.footer .sep, .site-footer .sep{ color: transparent; }
.footer .sep::before, .site-footer .sep::before{ content: "•"; color: inherit; }
.icon-sm{font-size:14px;margin-right:6px;}
@media (max-width:480px){
  .footer{gap:4px 8px;padding:10px 8px 18px;font-size:12.5px;}
  .footer .sep{margin:0 1px;}
  .icon-sm{font-size:13px;margin-right:4px;}
}

/* ========== REFUND / PRIVACY — shared page scaffold ========== */
/* Both refund.html & privacy.html use main.wrap + .doc system */
main.wrap{
  max-width:920px;margin:0 auto;padding:18px 14px;background:var(--card-ghost);color:var(--text);line-height:1.6;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
@media (min-width:900px){ main.wrap{padding:26px 20px 40px;} }
main.wrap .doc{
  background:var(--card-ghost);
  border:0; /* remove hard border to avoid double-line seam at right edge */
  box-shadow:0 6px 14px rgba(0,0,0,.06);
  border-radius:14px;
  padding:16px;
}
@media (min-width:900px){ main.wrap .doc{padding:20px 22px;} }
main.wrap .doc-title{
  display:flex;align-items:center;gap:10px;color:var(--brand-blue);
  font-weight:800;font-size:28px;line-height:1.25;margin:4px 0 12px;
}
@media (min-width:900px){ main.wrap .doc-title{font-size:32px;} }
main.wrap p{margin:8px 0;}
main.wrap .muted{color:var(--muted);}
main.wrap .hr{height:1px;background:var(--border);margin:14px 0;border-radius:1px;}
/* Refund-only note block still available via .warn */
main.wrap .warn{background:var(--warn-bg);border:1px solid var(--warn-bd);color:var(--warn-tx);padding:12px 14px;border-radius:10px;margin:12px 0;}
/* Shared footer row used on these pages too */
main.wrap .footer{display:flex;flex-wrap:wrap;align-items:center;column-gap:12px;row-gap:8px;justify-content:center;color:var(--muted);margin-top:14px;text-align:center;width:100%}

/* Injected site footer (footer-loader) — make it consistent across all pages */
.site-footer{
  position: fixed;
  bottom: 0; left: 0; width: 100%;
  background: #f9f9f9;
  text-align: center;
  padding: 6px 8px 10px;
  font-size: 13px; color: #000;
  border-top: 1px solid #ddd;
  box-shadow: 0 -4px 10px rgba(0,0,0,.06);
}
.site-footer nav{ display:flex; flex-wrap:wrap; justify-content:center; align-items:center; column-gap:12px; row-gap:8px; }
.site-footer nav a{ color:#0b51c9; text-decoration:none; padding:6px 10px; border-radius:8px; background:transparent; box-shadow:none; transition: color .18s ease, text-shadow .18s ease; }
.site-footer nav a:hover, .site-footer nav a:focus-visible{ outline:none; text-shadow:0 0 10px rgba(13,71,161,.25); }
.site-footer nav a.active{ color:#c62828; text-shadow:0 0 10px rgba(198,40,40,.30); }
.site-footer .sep{ opacity:.45; margin:0 2px; }
.site-footer p{ margin:4px 0 0; color:#64748b; }

/* Phone layout: pack links into exactly two rows with small gap */
@media (max-width: 720px){
  .site-footer nav{
    display: grid;
    grid-auto-flow: column;
    grid-template-rows: repeat(2, auto);
    grid-auto-columns: max-content;
    justify-content: center;
    align-content: center;
    column-gap: 6px;
    row-gap: 4px;
  }
  .site-footer nav a{ font-size: 12px; padding: 3px 5px; }
  .site-footer p{ font-size: 12px; }
  /* separators take space on small screens — hide them */
  .site-footer .sep{ display:none; }
  /* In case some pages still use inline .footer container */
  .footer{
    display: grid;
    grid-auto-flow: column;
    grid-template-rows: repeat(2, auto);
    grid-auto-columns: max-content;
    justify-content: center;
    align-content: center;
    column-gap: 6px;
    row-gap: 4px;
  }
  .footer a{ font-size: 12px; padding: 3px 5px; }
  .footer .sep{ display:none; }
}
main.wrap .icon-sm{font-size:14px;line-height:1;}
main.wrap .sep{width:6px;height:6px;border-radius:50%;background:var(--border);display:inline-block;margin:0 4px;}
/* Lists & links inside .doc */
main.wrap .doc ul, main.wrap .doc ol{margin:8px 0 8px 18px;padding:0;}
main.wrap .doc li{margin:4px 0;}
main.wrap .doc a{color:var(--brand-blue);text-decoration:underline;text-underline-offset:2px;}
main.wrap .doc a:hover{opacity:.9;}
/* Print-friendly */
@media print{
  main.wrap{max-width:100%;padding:0;color:#000;background:#fff;}
  main.wrap .doc{background:#fff;border-color:#ddd;}
  main.wrap .doc a{color:#000;text-decoration:none;} 
}

/* Caret glyph (down triangle) */
.faq-arrow::before{ content: "\25BC" !important; }
