/* ============================================================
   TROPIC PAWS — Design System
   Tropical playful: bright aqua + mango on white.
   Rounded type (Fredoka + Nunito), pill buttons, sticker cards.
   Edit the tokens below to re-theme the whole site.
   ============================================================ */

:root{
  /* Brand color tokens */
  --aqua:        #00A5B5;   /* primary brand aqua */
  --aqua-deep:   #00707C;   /* text-safe aqua (links, labels) */
  --aqua-dark:   #0B3C44;   /* deep teal ink — headings, footer */
  --aqua-mist:   #E5F7F8;   /* pale aqua section tint */
  --aqua-soft:   #BFEDF0;   /* borders, chips */
  --mango:       #FFA62B;   /* CTA accent */
  --mango-deep:  #E68A00;   /* CTA hover */
  --mango-tint:  #FFF3E0;   /* warm tint */
  --sand:        #FFF9F0;   /* warm section background */
  --coral:       #FF6B57;   /* tiny pops: badges, hearts */
  --white:       #FFFFFF;
  --ink:         #16323A;   /* body text */
  --ink-soft:    #4E6B73;   /* secondary text */
  --line:        #E3EEF0;   /* hairlines */

  /* Type */
  --font-display:'Baloo 2', 'Trebuchet MS', sans-serif;
  --font-body:   'Quicksand', 'Segoe UI', sans-serif;

  /* Shape & motion */
  --r-sm: 12px;
  --r-md: 20px;
  --r-lg: 28px;
  --r-pill: 999px;
  --shadow-sm: 0 2px 10px rgba(11,60,68,.07);
  --shadow-md: 0 10px 30px rgba(11,60,68,.10);
  --shadow-lg: 0 18px 50px rgba(11,60,68,.14);
  --ease-pop: cubic-bezier(.34,1.56,.64,1);
  --speed: .22s;

  --container: 1180px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  font-size:17px;line-height:1.65;color:var(--ink);
  background:var(--white);
  overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%}
a{color:var(--aqua-deep);text-decoration:none}
ul,ol{list-style:none}
button{font:inherit;background:none;border:0;cursor:pointer}
input,select,textarea{font:inherit}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.15;color:var(--aqua-dark);letter-spacing:.2px}
strong,b{font-weight:800}
::selection{background:var(--mango);color:#fff}

.container{max-width:var(--container);margin:0 auto;padding:0 22px}
.hide-sm{display:flex}
@media (max-width:760px){.hide-sm{display:none!important}}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-display);font-weight:600;font-size:16.5px;
  padding:15px 30px;border-radius:var(--r-pill);
  transition:transform var(--speed) var(--ease-pop), box-shadow var(--speed), background var(--speed);
  cursor:pointer;touch-action:manipulation;min-height:48px;
}
.btn svg{width:19px;height:19px;flex:none}
.btn:active{transform:scale(.97)}
.btn--mango{background:var(--mango);color:#5B3200;box-shadow:0 6px 18px rgba(255,166,43,.4)}
.btn--mango:hover{background:var(--mango-deep);color:#fff;transform:translateY(-2px);box-shadow:0 10px 26px rgba(230,138,0,.42)}
.btn--aqua{background:var(--aqua);color:#fff;box-shadow:0 6px 18px rgba(0,165,181,.32)}
.btn--aqua:hover{background:var(--aqua-deep);transform:translateY(-2px)}
.btn--ghost{background:#fff;color:var(--aqua-deep);border:2px solid var(--aqua-soft)}
.btn--ghost:hover{border-color:var(--aqua);transform:translateY(-2px)}
.btn--block{width:100%}

/* ---------- Header ---------- */
.site-head{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.topbar{background:var(--aqua-dark);color:#CFEFF2;font-size:13.5px}
.topbar .container{display:flex;justify-content:space-between;align-items:center;min-height:36px;gap:14px}
.topbar a{color:#CFEFF2;display:inline-flex;align-items:center;gap:6px}
.topbar a:hover{color:#fff}
.topbar svg{width:14px;height:14px}
.tb-badge{color:var(--mango);font-weight:800}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:76px}
.brand{display:flex;align-items:center;gap:11px}
.brand-badge{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--aqua),#19c3d3);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--shadow-sm);flex:none}
.brand-badge svg{width:26px;height:26px}
.brand-txt{display:flex;flex-direction:column;line-height:1.1}
.brand-txt b{font-family:var(--font-display);font-weight:600;font-size:21px;color:var(--aqua-dark)}
.brand-txt span{font-size:12px;color:var(--aqua-deep);font-weight:700;letter-spacing:.6px;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links>li>a{
  display:inline-flex;align-items:center;gap:5px;padding:10px 14px;border-radius:var(--r-pill);
  font-family:var(--font-display);font-weight:500;font-size:15.5px;color:var(--aqua-dark);
  transition:background var(--speed),color var(--speed);
}
.nav-links>li>a:hover,.nav-links>li>a.is-active{background:var(--aqua-mist);color:var(--aqua-deep)}
.nav-links svg{width:15px;height:15px}
.has-drop{position:relative}
.drop{
  position:absolute;top:calc(100% + 8px);left:0;min-width:300px;background:#fff;border-radius:var(--r-md);
  box-shadow:var(--shadow-lg);padding:10px;opacity:0;visibility:hidden;transform:translateY(8px);
  transition:all var(--speed) ease;
}
.has-drop:hover .drop,.has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateY(0)}
.drop a{display:flex;gap:12px;align-items:center;padding:11px 12px;border-radius:var(--r-sm);transition:background var(--speed)}
.drop a:hover{background:var(--aqua-mist)}
.drop .di{width:40px;height:40px;border-radius:12px;background:var(--aqua-mist);color:var(--aqua-deep);display:flex;align-items:center;justify-content:center;flex:none}
.drop .di svg{width:20px;height:20px}
.drop b{display:block;font-size:15px;color:var(--aqua-dark)}
.drop small{color:var(--ink-soft);font-size:12.5px}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-phone{display:flex;align-items:center;gap:9px;font-weight:800;color:var(--aqua-dark);font-size:15.5px;line-height:1.15}
.nav-phone small{display:block;font-weight:700;font-size:11.5px;color:var(--ink-soft)}
.nav-phone .pi{width:40px;height:40px;border-radius:50%;background:var(--mango-tint);color:var(--mango-deep);display:flex;align-items:center;justify-content:center}
.nav-phone .pi svg{width:18px;height:18px}
.burger{display:none;width:46px;height:46px;border-radius:50%;background:var(--aqua-mist);color:var(--aqua-dark);align-items:center;justify-content:center}
.burger svg{width:22px;height:22px}
@media (max-width:1040px){
  .nav-links{display:none}
  .nav-phone{display:none}
  .burger{display:flex}
}
@media (max-width:560px){.nav-cta .btn{padding:11px 18px;font-size:14.5px}}

/* ---------- Mobile drawer ---------- */
.drawer{position:fixed;inset:0;z-index:1000;pointer-events:none}
.drawer-scrim{position:absolute;inset:0;background:rgba(11,60,68,.5);opacity:0;transition:opacity .28s}
.drawer-panel{
  position:absolute;top:0;right:0;height:100%;width:min(360px,88vw);background:#fff;
  padding:22px;transform:translateX(102%);transition:transform .32s var(--ease-pop);
  display:flex;flex-direction:column;overflow-y:auto;border-radius:24px 0 0 24px;
}
.drawer.is-open{pointer-events:auto}
.drawer.is-open .drawer-scrim{opacity:1}
.drawer.is-open .drawer-panel{transform:translateX(0)}
.dh{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.drawer-close{width:44px;height:44px;border-radius:50%;background:var(--aqua-mist);display:flex;align-items:center;justify-content:center;color:var(--aqua-dark)}
.drawer-close svg{width:20px;height:20px}
.dl{display:block;padding:13px 12px;border-radius:var(--r-sm);font-family:var(--font-display);font-weight:500;font-size:17px;color:var(--aqua-dark)}
.dl:hover{background:var(--aqua-mist)}
.dl--sub{padding-left:26px;font-size:15.5px;color:var(--ink-soft)}

/* ---------- Sections ---------- */
.section{padding:84px 0}
.section--mist{background:var(--aqua-mist)}
.section--sand{background:var(--sand)}
.section--dark{background:var(--aqua-dark);color:#D8F0F2}
.section--dark h2,.section--dark h3{color:#fff}
.kicker{
  display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:600;
  font-size:13.5px;letter-spacing:1.6px;text-transform:uppercase;color:var(--aqua-deep);
  background:#fff;border:2px solid var(--aqua-soft);padding:7px 16px;border-radius:var(--r-pill);margin-bottom:18px;
}
.kicker svg{width:15px;height:15px;color:var(--mango)}
.section--dark .kicker{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2);color:#9FE0E6}
.h2{font-size:clamp(30px,4.4vw,44px);margin-bottom:16px}
.lead{font-size:18.5px;color:var(--ink-soft);max-width:640px}
.section--dark .lead{color:#A9D5DA}
.center{text-align:center}
.center .lead,.center .kicker{margin-left:auto;margin-right:auto}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{position:relative;background:var(--aqua-dark);color:#fff;overflow:hidden}
.page-hero .container{position:relative;z-index:2;padding-top:76px;padding-bottom:96px}
.page-hero h1{color:#fff;font-size:clamp(34px,5.2vw,54px);max-width:760px;margin-bottom:16px}
.page-hero .lead{color:#BFE6EA;max-width:620px}
.ph-img{position:absolute;inset:0;z-index:0}
.ph-img img{width:100%;height:100%;object-fit:cover;opacity:.34}
.ph-grad{position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(11,60,68,.94) 30%,rgba(11,60,68,.55) 70%,rgba(0,165,181,.35))}
.ph-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}
.crumbs{display:flex;flex-wrap:wrap;gap:7px;font-size:13.5px;font-weight:700;color:#8FCBD2;margin-bottom:22px}
.crumbs a{color:#C9ECEF}
.crumbs a:hover{color:#fff}
.crumbs span[aria-hidden]{color:#5B97A0}

/* Wave divider */
.wave{display:block;width:100%;height:54px;margin-bottom:-1px}
.wave--flip{transform:scaleY(-1);margin-bottom:0;margin-top:-1px}

/* ---------- Quick answer (AEO) ---------- */
.quick-answer{
  background:#fff;border:2px solid var(--aqua-soft);border-radius:var(--r-lg);
  padding:26px 28px;box-shadow:var(--shadow-sm);margin-bottom:34px;
}
.quick-answer .qa-tag{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-display);font-weight:600;font-size:12.5px;letter-spacing:1.4px;text-transform:uppercase;color:#fff;background:var(--aqua);padding:5px 13px;border-radius:var(--r-pill);margin-bottom:12px}
.quick-answer .qa-tag svg{width:13px;height:13px}
.quick-answer p{font-size:17.5px}

/* Key facts table */
.facts{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm);font-size:16px}
.facts th,.facts td{padding:13px 18px;text-align:left;border-bottom:1px solid var(--line)}
.facts tr:last-child th,.facts tr:last-child td{border-bottom:0}
.facts th{font-family:var(--font-display);font-weight:600;color:var(--aqua-dark);background:var(--aqua-mist);width:42%}
.facts td{font-variant-numeric:tabular-nums}

/* ---------- Cards ---------- */
.grid{display:grid;gap:24px}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
@media (max-width:980px){.grid--3,.grid--4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}}

.card{
  background:#fff;border-radius:var(--r-lg);padding:30px;box-shadow:var(--shadow-sm);
  border:2px solid transparent;transition:transform var(--speed) var(--ease-pop),box-shadow var(--speed),border-color var(--speed);
}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--aqua-soft)}
.card .ci{width:58px;height:58px;border-radius:18px;background:var(--aqua-mist);color:var(--aqua-deep);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.card .ci svg{width:28px;height:28px}
.card .ci--mango{background:var(--mango-tint);color:var(--mango-deep)}
.card h3{font-size:21px;margin-bottom:9px}
.card p{color:var(--ink-soft);font-size:15.5px}

/* Price cards */
.price-card{
  background:#fff;border-radius:var(--r-lg);padding:32px;box-shadow:var(--shadow-sm);
  border:2px solid var(--line);display:flex;flex-direction:column;position:relative;
}
.price-card--hot{border-color:var(--mango);box-shadow:var(--shadow-md)}
.pc-flag{position:absolute;top:-15px;left:50%;transform:translateX(-50%);background:var(--mango);color:#5B3200;font-family:var(--font-display);font-weight:600;font-size:12.5px;letter-spacing:1.2px;text-transform:uppercase;padding:5px 16px;border-radius:var(--r-pill);white-space:nowrap}
.price-card h3{font-size:21px}
.pc-price{font-family:var(--font-display);font-weight:600;font-size:42px;color:var(--aqua-deep);margin:10px 0 2px}
.pc-price small{font-size:16px;color:var(--ink-soft);font-weight:500}
.pc-note{font-size:14px;color:var(--ink-soft);margin-bottom:16px}
.pc-list{margin:14px 0 22px;display:grid;gap:9px}
.pc-list li{display:flex;gap:10px;align-items:flex-start;font-size:15.5px}
.pc-list svg{width:18px;height:18px;color:var(--aqua);flex:none;margin-top:3px}
.price-card .btn{margin-top:auto}

/* Pricing tables */
.ptable{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm)}
.ptable caption{caption-side:top;text-align:left;font-family:var(--font-display);font-weight:600;font-size:19px;color:var(--aqua-dark);padding:0 4px 12px}
.ptable th,.ptable td{padding:14px 18px;border-bottom:1px solid var(--line);text-align:left;font-size:15.5px}
.ptable thead th{background:var(--aqua-dark);color:#fff;font-family:var(--font-display);font-weight:500;font-size:14.5px;letter-spacing:.6px}
.ptable tbody tr:last-child td{border-bottom:0}
.ptable td:last-child{font-weight:800;color:var(--aqua-deep);font-variant-numeric:tabular-nums;white-space:nowrap}
.tbl-scroll{overflow-x:auto;border-radius:var(--r-md)}

/* Checklist */
.checks{display:grid;gap:11px}
.checks li{display:flex;gap:11px;align-items:flex-start}
.checks svg{width:21px;height:21px;color:var(--aqua);flex:none;margin-top:3px}
.checks b{color:var(--aqua-dark)}

/* Chips */
.chip{display:inline-flex;align-items:center;gap:7px;background:#fff;border:2px solid var(--aqua-soft);color:var(--aqua-deep);font-weight:800;font-size:13.5px;padding:7px 14px;border-radius:var(--r-pill)}
.chip svg{width:14px;height:14px;color:var(--mango)}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
@media (max-width:980px){.steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.steps{grid-template-columns:1fr}}
.step{background:#fff;border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-sm);position:relative}
.step-num{
  width:46px;height:46px;border-radius:50%;background:var(--mango);color:#5B3200;
  font-family:var(--font-display);font-weight:600;font-size:20px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;
}
.step h3{font-size:19px;margin-bottom:8px}
.step p{font-size:15px;color:var(--ink-soft)}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto;display:grid;gap:14px}
.faq-item{background:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-sm);overflow:hidden;border:2px solid transparent;transition:border-color var(--speed)}
.faq-item.is-open{border-color:var(--aqua-soft)}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;text-align:left;
  padding:20px 24px;font-family:var(--font-display);font-weight:500;font-size:17.5px;color:var(--aqua-dark);
}
.faq-q .fx{width:34px;height:34px;border-radius:50%;background:var(--aqua-mist);color:var(--aqua-deep);display:flex;align-items:center;justify-content:center;flex:none;transition:transform .28s var(--ease-pop),background var(--speed)}
.faq-q .fx svg{width:17px;height:17px}
.faq-item.is-open .fx{transform:rotate(45deg);background:var(--mango);color:#5B3200}
.faq-a{max-height:0;overflow:hidden;transition:max-height .34s ease}
.faq-a-in{padding:0 24px 22px;color:var(--ink-soft);font-size:16px}

/* ---------- Testimonials ---------- */
.t-card{background:#fff;border-radius:var(--r-lg);padding:30px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px}
.t-stars{display:flex;gap:3px;color:var(--mango)}
.t-stars svg{width:18px;height:18px}
.t-card p{font-size:15.5px;color:var(--ink)}
.t-who{display:flex;align-items:center;gap:11px;margin-top:auto}
.t-ava{width:42px;height:42px;border-radius:50%;background:var(--aqua);color:#fff;font-family:var(--font-display);font-weight:600;display:flex;align-items:center;justify-content:center;flex:none}
.t-who b{display:block;font-size:15px;color:var(--aqua-dark)}
.t-who small{color:var(--ink-soft);font-size:12.5px}

/* ---------- CTA band ---------- */
.cta-band{position:relative;background:linear-gradient(120deg,var(--aqua) 0%,#13bccb 55%,var(--aqua-deep) 100%);border-radius:var(--r-lg);padding:58px 50px;color:#fff;overflow:hidden;text-align:center}
.cta-band h2{color:#fff;font-size:clamp(28px,3.8vw,40px);margin-bottom:12px}
.cta-band p{color:#D9F6F8;font-size:18px;max-width:560px;margin:0 auto 28px}
.cta-band .ph-ctas{justify-content:center;margin-top:0}
.cta-paw{position:absolute;color:rgba(255,255,255,.12);width:130px;height:130px}
@media (max-width:640px){.cta-band{padding:44px 24px}}

/* ---------- Forms ---------- */
.form{display:grid;gap:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:640px){.form-row{grid-template-columns:1fr}}
.field label{display:block;font-family:var(--font-display);font-weight:500;font-size:14.5px;color:var(--aqua-dark);margin-bottom:7px}
.field label span{color:var(--coral)}
.field input,.field select,.field textarea{
  width:100%;padding:14px 18px;border:2px solid var(--line);border-radius:var(--r-md);
  background:#fff;font-size:16px;color:var(--ink);transition:border-color var(--speed),box-shadow var(--speed);
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--aqua);box-shadow:0 0 0 4px rgba(0,165,181,.14)}
.field textarea{min-height:130px;resize:vertical}
.form-note{font-size:13.5px;color:var(--ink-soft)}
.form-success{display:none;background:var(--aqua-mist);border:2px solid var(--aqua-soft);border-radius:var(--r-md);padding:22px;text-align:center;font-weight:800;color:var(--aqua-deep)}
.form.is-sent{display:none}
.form-success.is-sent{display:block}

/* ---------- Footer ---------- */
.site-foot{background:var(--aqua-dark);color:#A9D5DA;padding:0 0 36px;position:relative}
.site-foot .wave--foot{color:var(--aqua-dark)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:38px;padding:60px 0 44px}
@media (max-width:980px){.foot-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.foot-grid{grid-template-columns:1fr}}
.site-foot h4{color:#fff;font-size:16.5px;margin-bottom:16px;letter-spacing:.4px}
.site-foot a{color:#A9D5DA;transition:color var(--speed)}
.site-foot a:hover{color:#fff}
.foot-links{display:grid;gap:9px;font-size:15px}
.foot-brand p{font-size:14.5px;margin:14px 0 18px;max-width:300px}
.foot-contact{display:grid;gap:12px;font-size:15px}
.foot-contact a,.foot-contact div{display:flex;gap:10px;align-items:flex-start}
.foot-contact svg{width:17px;height:17px;flex:none;margin-top:4px;color:var(--mango)}
.foot-social{display:flex;gap:10px;margin-top:16px}
.foot-social a{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center}
.foot-social a:hover{background:var(--aqua)}
.foot-social svg{width:18px;height:18px}
.foot-base{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;font-size:13px;color:#7FB3BA}
.foot-base a{color:#7FB3BA}

/* Sticky mobile call bar */
.callbar{
  position:fixed;left:0;right:0;bottom:0;z-index:90;display:none;
  background:#fff;border-top:1px solid var(--line);padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  grid-template-columns:1fr 1fr;gap:10px;box-shadow:0 -8px 30px rgba(11,60,68,.12);
}
.callbar .btn{padding:12px 10px;font-size:15px}
@media (max-width:760px){.callbar{display:grid}body{padding-bottom:74px}}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s var(--ease-pop)}
.reveal.is-in{opacity:1;transform:none}
.reveal-d1{transition-delay:.08s}
.reveal-d2{transition-delay:.16s}
.reveal-d3{transition-delay:.24s}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}

/* Focus visibility */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:3px solid var(--mango);outline-offset:2px;border-radius:6px;
}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--mango);color:#5B3200;font-weight:800;padding:12px 20px;border-radius:0 0 14px 0;z-index:2000}
.skip-link:focus{left:0}
