/* =========================================================
   CARIOCA CONNECTION — "Carioca Sketchbook" design system
   One accent (yellow), cream paper, condensed display + clean sans.
   ========================================================= */

:root{
  --ink:#1B1B1B; --ink-70:rgba(27,27,27,.70); --ink-50:rgba(27,27,27,.50);
  --cream:#FBF4E2; --paper:#FFFDF6; --warm:#F6EAC9;
  --yellow:#FFD43B; --yellow-soft:#FFEFA8; --green:#2E9E4F; --mint:#DCEFD2;
  --red:#E0463C; --blush:#F8D8CF; --blue:#3D7DC4; --sky:#D7E5F3;
  --butter:#FBE9A0;
  --display:'Barlow Condensed',sans-serif; --body:'Inter',sans-serif;
  --r:18px; --r-sm:14px; --r-btn:999px; --maxw:1240px;
  --ease:cubic-bezier(.32,.72,0,1);
  --shadow:0 1px 2px rgba(27,20,0,.04), 0 22px 48px -26px rgba(27,20,0,.30);
  --shadow-sm:0 1px 2px rgba(27,20,0,.05), 0 10px 24px -16px rgba(27,20,0,.25);
  --pad:104px;
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0; background:var(--cream); color:var(--ink);
  font-family:var(--body); font-size:18px; line-height:1.65;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video,table{max-width:100%;}
img{display:block;}
a{color:inherit; text-decoration:none;}
button{font-family:inherit;}

/* ---- paper grain overlay ---- */
.grain{
  position:fixed; inset:0; z-index:9999; pointer-events:none;
  opacity:.045; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---- layout primitives ---- */
.band{ padding-block:var(--pad); padding-inline:max(24px, calc((100vw - var(--maxw))/2)); }
.band.tight{ --pad:72px; }
.wrap{ max-width:var(--maxw); margin-inline:auto; }
.band.cream{ background:var(--cream); }
.band.paper{ background:var(--paper); }
.band.warm{ background:var(--warm); }
.band.ink{ background:var(--ink); color:var(--cream); }
.band.red{ background:var(--red); color:#fff; }
.band.ink .ink-70,.band.red .ink-70{ color:rgba(255,255,255,.72); }

/* ---- typography ---- */
.h1,.h2,.h3,.display{ font-family:var(--display); font-weight:900; text-transform:uppercase; letter-spacing:-.01em; line-height:.92; margin:0; text-wrap:balance; }
.h1{ font-size:clamp(44px,6vw,92px); }
.h2{ font-size:clamp(36px,4.6vw,66px); }
.h3{ font-size:clamp(26px,3vw,38px); }
.lede{ font-size:clamp(19px,2vw,22px); line-height:1.55; color:var(--ink-70); max-width:60ch; text-wrap:pretty; }
.band.ink .lede,.band.red .lede{ color:rgba(255,255,255,.82); }
p{ margin:0 0 1em; text-wrap:pretty; }
.measure{ max-width:62ch; }
.big-num{ font-family:var(--display); font-weight:900; line-height:.9; font-size:clamp(40px,5vw,64px); }

/* ---- eyebrow pill ---- */
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--display); font-weight:700; font-size:13px; letter-spacing:.18em; text-transform:uppercase;
  background:var(--yellow); color:var(--ink); padding:7px 14px 6px; border-radius:var(--r-btn);
  transform:rotate(-1.2deg); box-shadow:var(--shadow-sm);
}
.eyebrow::before{ content:""; width:8px; height:8px; border-radius:50%; background:var(--green); display:inline-block; }
.eyebrow.plain::before{ display:none; }
.band.ink .eyebrow,.band.red .eyebrow{ background:var(--yellow); color:var(--ink); }

/* ---- flag dots ---- */
.flagdots{ display:flex; gap:7px; }
.flagdots span{ width:13px; height:13px; border-radius:50%; transform:rotate(-8deg); box-shadow:var(--shadow-sm); }
.flagdots .d1{ background:var(--green); }
.flagdots .d2{ background:var(--yellow); }
.flagdots .d3{ background:var(--red); }
.flagdots .d4{ background:var(--blue); }

/* ---- highlighter + underline ---- */
.mark{
  background:linear-gradient(120deg, var(--yellow) 0%, var(--yellow) 100%);
  background-repeat:no-repeat; background-size:100% 64%; background-position:0 72%;
  padding:0 .06em; box-decoration-break:clone; -webkit-box-decoration-break:clone;
}
.uline{ position:relative; white-space:nowrap; }
.uline::after{
  content:""; position:absolute; left:-2%; right:-2%; bottom:-.16em; height:.34em;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 18' preserveAspectRatio='none'%3E%3Cpath d='M4 11 C70 4 150 16 296 7' stroke='%23E0463C' stroke-width='4' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center/100% 100%;
}
/* on dark grounds: yellow text, no wash */
.band.ink .mark,.band.red .mark{ background:none; color:var(--yellow); padding:0; }

/* ---- buttons ---- */
.btn{
  display:inline-flex; align-items:center; gap:12px; cursor:pointer;
  font-family:var(--display); font-weight:700; font-size:18px; letter-spacing:.01em; text-transform:uppercase;
  padding:13px 16px 13px 24px; border-radius:var(--r-btn); border:2px solid var(--ink);
  background:var(--paper); color:var(--ink); transition:transform .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease);
  box-shadow:var(--shadow-sm); line-height:1;
}
.btn .arrow{
  display:grid; place-items:center; width:30px; height:30px; border-radius:50%;
  background:var(--yellow); color:var(--ink); transition:transform .3s var(--ease); flex:none;
}
.btn:hover{ transform:translateY(-2px); }
.btn:hover .arrow{ transform:translateX(4px); }
.btn.yellow{ background:var(--yellow); border-color:var(--ink); }
.btn.yellow .arrow{ background:var(--ink); color:var(--yellow); }
.btn.ghost{ background:transparent; }
.band.ink .btn{ background:transparent; color:var(--cream); border-color:rgba(255,255,255,.4); }
.band.ink .btn.yellow{ background:var(--yellow); color:var(--ink); border-color:var(--yellow); }
.band.ink .btn.yellow .arrow{ background:var(--ink); color:var(--yellow); }

/* ---- cards ---- */
.card{ background:var(--paper); border-radius:var(--r); padding:30px; box-shadow:var(--shadow); border:1px solid rgba(27,20,0,.06); }
.card .tile{
  width:54px; height:54px; border-radius:14px; display:grid; place-items:center;
  background:var(--yellow-soft); transform:rotate(-3deg); margin-bottom:18px; font-size:26px;
}
.card h3{ font-family:var(--display); font-weight:800; text-transform:uppercase; letter-spacing:-.01em; font-size:24px; margin:0 0 8px; line-height:1; }
.card p{ color:var(--ink-70); font-size:16px; margin:0; }
.sticky-note{ color:var(--ink) !important; }
.sticky-note.blush{ background:var(--blush); } .sticky-note.blush .tile{ background:#fff; }
.sticky-note.sky{ background:var(--sky); } .sticky-note.sky .tile{ background:#fff; }
.sticky-note.mint{ background:var(--mint); } .sticky-note.mint .tile{ background:#fff; }
.sticky-note.butter{ background:var(--butter); } .sticky-note.butter .tile{ background:#fff; }
.sticky-note p{ color:var(--ink-70) !important; }

/* ---- grids ---- */
.grid{ display:grid; gap:24px; }
.g2{ grid-template-columns:repeat(2,1fr); }
.g3{ grid-template-columns:repeat(3,1fr); }
.g4{ grid-template-columns:repeat(4,1fr); }

/* ---- photo frame ---- */
.frame{ position:relative; border-radius:var(--r); overflow:hidden; border:6px solid var(--paper); box-shadow:var(--shadow); transform:rotate(1.4deg); }
.frame.left{ transform:rotate(-1.4deg); }
.ph{ position:relative; background:
   repeating-linear-gradient(135deg, rgba(27,20,0,.05) 0 10px, transparent 10px 20px), var(--warm);
   display:grid; place-items:center; min-height:280px; }
.ph .lbl{ font-family:ui-monospace,Menlo,monospace; font-size:12px; letter-spacing:.04em; color:var(--ink-50); text-align:center; padding:14px; }
.tag{
  position:absolute; left:14px; bottom:14px; z-index:2; background:var(--ink); color:var(--cream);
  font-family:var(--display); font-weight:700; text-transform:uppercase; letter-spacing:.04em; font-size:14px;
  padding:7px 13px; border-radius:var(--r-btn); transform:rotate(-3deg); box-shadow:var(--shadow-sm);
}

/* ---- stats ribbon ---- */
.stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.stat{ text-align:center; }
.stat .k{ font-family:var(--display); font-weight:900; font-size:clamp(40px,5vw,64px); line-height:.9; color:var(--ink); }
.band.ink .stat .k{ color:var(--yellow); }
.stat .v{ font-size:14px; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-70); margin-top:6px; }
.band.ink .stat .v{ color:rgba(255,255,255,.72); }

/* ---- check list ---- */
.checks{ list-style:none; margin:0; padding:0; display:grid; gap:14px; }
.checks li{ display:flex; gap:12px; align-items:flex-start; font-size:17px; }
.checks li::before{ content:""; flex:none; width:24px; height:24px; border-radius:50%; background:var(--mint); margin-top:2px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6 12.5l3.5 3.5L18 7.5' stroke='%232E9E4F' stroke-width='2.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:center; }
.crosses{ list-style:none; margin:0; padding:0; display:grid; gap:14px; }
.crosses li{ display:flex; gap:12px; align-items:flex-start; font-size:17px; color:var(--ink-70); }
.crosses li::before{ content:""; flex:none; width:24px; height:24px; border-radius:50%; background:var(--blush); margin-top:2px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M8 8l8 8M16 8l-8 8' stroke='%23E0463C' stroke-width='2.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:center; }

/* ---- pricing ---- */
.toggle{ display:inline-flex; align-items:center; gap:0; background:var(--paper); border:2px solid var(--ink); border-radius:var(--r-btn); padding:4px; box-shadow:var(--shadow-sm); }
.toggle button{ border:none; background:transparent; cursor:pointer; font-family:var(--display); font-weight:700; text-transform:uppercase; letter-spacing:.04em; font-size:15px; padding:9px 18px; border-radius:var(--r-btn); color:var(--ink-70); transition:.2s var(--ease); }
.toggle button.on{ background:var(--ink); color:var(--cream); }
.save-pill{ display:inline-block; background:var(--green); color:#fff; font-family:var(--display); font-weight:700; text-transform:uppercase; font-size:12px; letter-spacing:.08em; padding:5px 11px; border-radius:var(--r-btn); transform:rotate(-1.2deg); }
.plan{ background:var(--paper); border-radius:var(--r); padding:32px; box-shadow:var(--shadow); border:1px solid rgba(27,20,0,.07); display:flex; flex-direction:column; }
.plan.featured{ border:2px solid var(--yellow); box-shadow:0 1px 2px rgba(27,20,0,.04), 0 30px 60px -30px rgba(27,20,0,.4); }
.plan .pop{ align-self:flex-start; background:var(--yellow); color:var(--ink); font-family:var(--display); font-weight:700; text-transform:uppercase; font-size:12px; letter-spacing:.08em; padding:5px 12px; border-radius:var(--r-btn); margin-bottom:14px; transform:rotate(-1.2deg); }
.plan .pname{ font-family:var(--display); font-weight:800; text-transform:uppercase; font-size:26px; letter-spacing:-.01em; }
.plan .price{ font-family:var(--display); font-weight:900; font-size:clamp(44px,5vw,60px); line-height:1; margin:10px 0 2px; }
.plan .price small{ font-family:var(--body); font-weight:600; font-size:18px; color:var(--ink-50); }
.plan .sub{ color:var(--ink-70); font-size:15px; margin-bottom:18px; }
.plan ul{ list-style:none; margin:0 0 24px; padding:0; display:grid; gap:11px; }
.plan ul li{ display:flex; gap:10px; font-size:15px; color:var(--ink-70); }
.plan ul li::before{ content:""; flex:none; width:20px; height:20px; border-radius:50%; background:var(--mint);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6 12.5l3.5 3.5L18 7.5' stroke='%232E9E4F' stroke-width='3' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:center; }
.plan .btn{ margin-top:auto; justify-content:center; }
.guarantee{ display:inline-flex; align-items:center; gap:10px; background:var(--paper); border:1px dashed rgba(27,20,0,.3); border-radius:var(--r-btn); padding:11px 20px; font-size:15px; color:var(--ink-70); }

/* ---- testimonials ---- */
.quote{ background:#fff; color:var(--ink); border-radius:var(--r); padding:28px; box-shadow:var(--shadow); }
.quote .stars{ color:var(--yellow); letter-spacing:3px; font-size:18px; margin-bottom:12px; -webkit-text-stroke:1px rgba(27,20,0,.25); }
.quote p{ font-size:17px; line-height:1.55; color:var(--ink); margin:0 0 16px; }
.quote .by{ font-family:var(--display); font-weight:700; text-transform:uppercase; letter-spacing:.04em; font-size:15px; }
.quote .by small{ display:block; font-family:var(--body); font-weight:500; text-transform:none; letter-spacing:0; color:var(--ink-50); font-size:13px; }

/* ---- FAQ ---- */
.faq{ border-top:1px solid rgba(27,20,0,.12); }
.faq details{ border-bottom:1px solid rgba(27,20,0,.12); }
.faq summary{ list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:20px; padding:22px 4px; font-family:var(--display); font-weight:700; text-transform:uppercase; letter-spacing:-.01em; font-size:clamp(19px,2.2vw,24px); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .pm{ flex:none; width:34px; height:34px; border-radius:50%; background:var(--yellow); display:grid; place-items:center; font-family:var(--body); font-weight:400; font-size:26px; line-height:1; transition:transform .3s var(--ease); }
.faq details[open] summary .pm{ transform:rotate(135deg); }
.faq .ans{ padding:0 4px 24px; color:var(--ink-70); font-size:17px; max-width:72ch; }

/* ---- compare table ---- */
.compare-scroll{ overflow-x:auto; -webkit-overflow-scrolling:touch; border-radius:var(--r); box-shadow:var(--shadow); }
table.compare{ border-collapse:collapse; width:100%; min-width:680px; background:var(--paper); }
table.compare th,table.compare td{ padding:16px 18px; text-align:left; border-bottom:1px solid rgba(27,20,0,.08); font-size:15px; }
table.compare thead th{ font-family:var(--display); font-weight:800; text-transform:uppercase; letter-spacing:.02em; font-size:17px; background:var(--warm); }
table.compare tbody td:not(:first-child){ text-align:center; }
table.compare .hl{ background:var(--yellow-soft); }
table.compare thead th.hl{ background:var(--yellow); }
table.compare .yes{ color:var(--green); font-weight:700; }
table.compare .no{ color:var(--ink-50); }
table.compare td:first-child{ font-weight:600; color:var(--ink); }

/* ---- misc helpers ---- */
.center{ text-align:center; }
.mt8{ margin-top:8px; } .mt16{ margin-top:16px; } .mt24{ margin-top:24px; } .mt32{ margin-top:32px; } .mt48{ margin-top:48px; }
.head-block{ display:grid; gap:18px; justify-items:start; margin-bottom:48px; }
.head-block.center{ justify-items:center; text-align:center; margin-inline:auto; }
.btn-row{ display:flex; flex-wrap:wrap; gap:14px; }
.divider-note{ font-family:ui-monospace,Menlo,monospace; font-size:13px; color:var(--ink-50); }

/* hand-drawn sun */
.sun{ position:absolute; width:74px; height:74px; z-index:3; }
.sun.tr{ top:-26px; right:-22px; }

/* ---- sticky bar ---- */
.ccbar{ position:sticky; top:0; z-index:1000; backdrop-filter:saturate(1.2) blur(8px); background:rgba(251,244,226,.82); border-bottom:1px solid rgba(27,20,0,.08); }
.ccbar .inner{ max-width:var(--maxw); margin-inline:auto; display:flex; align-items:center; justify-content:space-between; gap:16px; padding:12px max(24px, calc((100vw - var(--maxw))/2)); }
.ccbar .inner{ padding-inline:max(20px, calc((100vw - var(--maxw))/2)); }
.brand{ display:flex; align-items:center; gap:10px; font-family:var(--display); font-weight:900; text-transform:uppercase; letter-spacing:-.01em; font-size:22px; }
.brand .dot{ width:13px; height:13px; border-radius:50%; background:var(--green); flex:none; }
.ccnav{ display:flex; align-items:center; gap:6px; }
.ccnav a{ font-family:var(--display); font-weight:700; text-transform:uppercase; letter-spacing:.02em; font-size:15px; color:var(--ink-70); padding:8px 12px; border-radius:var(--r-btn); transition:.2s var(--ease); }
.ccnav a:hover{ color:var(--ink); background:rgba(27,20,0,.05); }
.ccnav a.active{ color:var(--ink); }
.ccnav a.active::after{ content:""; display:block; height:.28em; margin-top:-3px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 18' preserveAspectRatio='none'%3E%3Cpath d='M4 11 C70 4 150 16 296 7' stroke='%23E0463C' stroke-width='4' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center/100% 100%; }
.ccbar .btn{ padding:9px 12px 9px 18px; font-size:15px; }
.ccbar .btn .arrow{ width:26px; height:26px; }
.burger{ display:none; width:44px; height:44px; border:2px solid var(--ink); border-radius:12px; background:var(--paper); cursor:pointer; align-items:center; justify-content:center; flex-direction:column; gap:4px; }
.burger span{ width:18px; height:2px; background:var(--ink); border-radius:2px; }
.mobile-menu{ display:none; flex-direction:column; gap:4px; padding:8px max(20px, calc((100vw - var(--maxw))/2)) 18px; border-top:1px solid rgba(27,20,0,.08); background:rgba(251,244,226,.96); }
.mobile-menu a{ font-family:var(--display); font-weight:700; text-transform:uppercase; font-size:18px; padding:12px 6px; border-bottom:1px solid rgba(27,20,0,.06); }
.mobile-menu.open{ display:flex; }

/* ---- footer ---- */
.ccfoot{ background:var(--ink); color:var(--cream); position:relative; }
.skyline{ width:100%; height:auto; display:block; }
.foot-inner{ max-width:var(--maxw); margin-inline:auto; padding:48px max(24px, calc((100vw - var(--maxw))/2)) 40px; display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
.ccfoot .brand{ color:var(--cream); }
.ccfoot p{ color:rgba(255,255,255,.6); font-size:15px; }
.foot-col h4{ font-family:var(--display); font-weight:800; text-transform:uppercase; letter-spacing:.06em; font-size:14px; color:rgba(255,255,255,.5); margin:0 0 14px; }
.foot-col a{ display:block; color:rgba(255,255,255,.82); font-size:15px; padding:5px 0; }
.foot-col a:hover{ color:var(--yellow); }
.foot-bottom{ border-top:1px solid rgba(255,255,255,.12); }
.foot-bottom .fb{ max-width:var(--maxw); margin-inline:auto; padding:20px max(24px, calc((100vw - var(--maxw))/2)); display:flex; flex-wrap:wrap; gap:12px; justify-content:space-between; align-items:center; font-size:14px; color:rgba(255,255,255,.55); }

/* =========================================================
   MOTION — one calm fade-up per section
   ========================================================= */
@media (prefers-reduced-motion:no-preference){
  @supports (animation-timeline:view()){
    .reveal{ animation:fadeup linear both; animation-timeline:view(); animation-range:entry 0% cover 26%; }
    @keyframes fadeup{ from{ opacity:0; transform:translateY(26px); } to{ opacity:1; transform:none; } }
  }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  :root{ --pad:72px; }
  .g4{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:860px){
  :root{ --pad:56px; }
  .ccnav, .ccbar .btn{ display:none; }
  .burger{ display:flex; }
  .g3,.g2,.g4{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:1fr; gap:14px; }
  .foot-inner{ grid-template-columns:1fr; gap:28px; }
  .hero-split{ grid-template-columns:1fr !important; }
  .hero-split .btn-row .btn{ width:100%; justify-content:center; }
}
@media (max-width:520px){
  :root{ --pad:48px; }
  body{ font-size:17px; }
  .frame{ transform:none; }
  .btn{ width:100%; justify-content:center; }
  .head-block .btn-row .btn{ width:100%; }
}
