/* ===========================================================
   PINYA — Concept 3 "Tropical Maximal" shared design system
   Used by every mockup page. Edit here once, applies sitewide.
   =========================================================== */
:root{
  --pineapple-yellow:#F4D35E;--pineapple-gold:#E8B923;
  --leaf-green:#2D5016;--dark-green:#1A3009;
  --cream:#FFF9E6;--light-yellow:#FFF1BF;--white:#FFFFFF;
  --charcoal:#2D2D2D;--black-coral:#5D6676;--coral:#E8734A;
  --ff-display:"Poppins",sans-serif;--ff-body:"Inter",sans-serif;--ff-ui:"Poppins",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--ff-body);color:var(--charcoal);background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
img{max-width:100%;display:block;}a{text-decoration:none;color:inherit;}svg{display:block;}
.wrap{max-width:1180px;margin:0 auto;padding-inline:28px;}
.icon{width:1em;height:1em;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;}

.btn{font-family:var(--ff-ui);font-weight:700;font-size:15px;display:inline-flex;align-items:center;gap:9px;padding:16px 30px;border-radius:100px;border:2.5px solid var(--dark-green);cursor:pointer;transition:box-shadow .15s ease,background .15s ease,transform .1s ease;box-shadow:4px 4px 0 var(--dark-green);will-change:box-shadow;}
.btn-primary{background:var(--pineapple-yellow);color:var(--dark-green);}
.btn-primary:hover{box-shadow:6px 6px 0 var(--dark-green);}
.btn-primary:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--dark-green);}
.btn-green{background:var(--leaf-green);color:var(--cream);}
.btn-green:hover{box-shadow:6px 6px 0 var(--dark-green);}
.btn-green:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--dark-green);}
.btn-white{background:var(--white);color:var(--dark-green);}
.btn-white:hover{box-shadow:6px 6px 0 var(--dark-green);}
.btn-white:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--dark-green);}
.btn .arrow{transition:transform .2s ease;}.btn:hover .arrow{transform:translateX(4px);}
a:focus,button:focus,.btn:focus{outline:none;}
.btn:focus-visible{outline:3px solid rgba(45,80,22,.45);outline-offset:3px;}

.chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--ff-ui);font-weight:700;font-size:13px;background:var(--white);border:2px solid var(--dark-green);border-radius:100px;padding:7px 15px;box-shadow:3px 3px 0 var(--dark-green);}
.chip .icon{width:15px;height:15px;color:var(--coral);}

/* ===== Navbar ===== */
header{position:sticky;top:0;z-index:50;background:var(--pineapple-yellow);border-bottom:3px solid var(--dark-green);}
/* real-site globe id maps to the mockup globe-card; non-interactive so the page scrolls through it */
#landingGlobeViz{position:absolute;inset:0;pointer-events:none;}
#landingGlobeViz canvas{display:block;background:transparent;pointer-events:none !important;}
.globe-card{pointer-events:none;}
.nav{display:flex;align-items:center;height:78px;}
.brand{display:flex;align-items:center;gap:14px;flex-shrink:0;}
.brand .mark{width:48px;height:48px;object-fit:contain;}
.brand .lock{display:flex;flex-direction:column;justify-content:center;line-height:1;}
.brand .name{font-family:var(--ff-ui);font-weight:800;font-size:23px;letter-spacing:.04em;color:var(--dark-green);line-height:1;}
.brand .tag{font-family:var(--ff-ui);font-weight:500;font-size:8.5px;letter-spacing:.22em;text-transform:uppercase;color:rgba(26,48,9,.62);margin-top:3px;background:none;border:none;padding:0;border-radius:0;}
.nav-links{display:flex;align-items:center;gap:26px;margin-left:40px;}
.nav-item{position:relative;}
.nav-links a.link{font-family:var(--ff-ui);font-weight:600;font-size:15px;color:var(--dark-green);display:inline-flex;align-items:center;gap:5px;padding:8px 0;cursor:pointer;position:relative;}
.nav-links a.link:hover{color:var(--coral);}
.nav-links a.link .chev{width:14px;height:14px;stroke-width:2.4;transition:transform .2s ease;}
.nav-item:hover a.link .chev{transform:rotate(180deg);}
.nav-links a.link.active{color:var(--dark-green);}
.nav-links a.link.active::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--coral);border-radius:3px;}
.post-only{display:none;}
body.logged-in .post-only{display:inline-flex;}
/* Guest-only: shown by default, hidden once logged in (mirror of post-only). */
body.logged-in .pre-only{display:none !important;}
.drop{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(8px);min-width:215px;background:var(--white);border:2.5px solid var(--dark-green);border-radius:16px;box-shadow:5px 5px 0 var(--dark-green);padding:8px;opacity:0;visibility:hidden;transition:opacity .18s ease,transform .18s ease;z-index:60;}
/* transparent bridge across the gap so the menu stays open while the cursor travels from the link to the options */
.drop::before{content:"";position:absolute;left:0;right:0;top:-16px;height:16px;}
.nav-item:hover .drop,.profile:hover .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.drop a{display:flex;align-items:center;gap:9px;font-family:var(--ff-ui);font-weight:500;font-size:13.5px;color:var(--charcoal);padding:9px 12px;border-radius:9px;white-space:nowrap;}
.drop a:hover{background:var(--light-yellow);color:var(--dark-green);}
.drop a .icon{width:16px;height:16px;color:var(--leaf-green);}
.nav-right{display:flex;align-items:center;gap:12px;flex-shrink:0;margin-left:auto;}
body.logged-in .signin{display:none;}
.profile{display:none;position:relative;}
body.logged-in .profile{display:inline-flex;}
.profile .pbtn{font-family:var(--ff-ui);font-weight:700;font-size:14px;display:inline-flex;align-items:center;gap:8px;background:var(--leaf-green);color:var(--cream);border:2.5px solid var(--dark-green);border-radius:100px;padding:9px 18px;box-shadow:3px 3px 0 var(--dark-green);cursor:pointer;}
.profile .pbtn .icon{width:17px;height:17px;}
.profile .drop{left:auto;right:0;transform:translateX(0) translateY(8px);min-width:185px;}
.profile:hover .drop{transform:translateX(0) translateY(0);}
.hamb{display:none;width:46px;height:46px;border:2.5px solid var(--dark-green);border-radius:12px;background:var(--white);box-shadow:3px 3px 0 var(--dark-green);cursor:pointer;align-items:center;justify-content:center;color:var(--dark-green);}
.hamb .icon{width:24px;height:24px;}
@media(max-width:980px){
  .nav{position:relative;}
  header .wrap{padding-inline:14px;}
  .nav-links{display:none;}
  .hamb{display:inline-flex;order:0;width:40px;height:40px;border-radius:10px;box-shadow:2px 2px 0 var(--dark-green);}
  .hamb .icon{width:20px;height:20px;}
  .brand{position:absolute;left:50%;transform:translateX(-50%);gap:0;}
  .brand .lock{display:none;}
  .brand .mark{width:46px;height:46px;}
  /* drawer header brand is not the centered top-nav logo: keep it inline with proper spacing */
  .drawer .dhead .brand{position:static;transform:none;gap:10px;}
  .drawer .dhead .brand .mark{width:40px;height:40px;}
  .nav-right{margin-left:auto;}
  .nav-right .signin{padding:8px 16px !important;font-size:13px;box-shadow:2px 2px 0 var(--dark-green) !important;}
  .profile .pbtn{padding:7px 13px;font-size:13px;box-shadow:2px 2px 0 var(--dark-green);}
  .profile .pbtn .chev{display:none;}
}

/* preview toggle */
.concept-banner{background:var(--coral);color:var(--white);font-family:var(--ff-ui);font-size:12.5px;text-align:center;padding:8px;letter-spacing:.04em;font-weight:600;}
.state-toggle{display:inline-flex;gap:0;border:1.5px solid rgba(255,255,255,.55);border-radius:100px;overflow:hidden;margin-left:12px;vertical-align:middle;}
.state-toggle button{font-family:var(--ff-ui);font-weight:600;font-size:11px;padding:3px 12px;background:transparent;color:#fff;border:none;cursor:pointer;}
.state-toggle button.on{background:#fff;color:var(--coral);}

/* mobile drawer */
.drawer-overlay{position:fixed;inset:0;background:rgba(26,48,9,.45);opacity:0;visibility:hidden;transition:opacity .2s ease;z-index:90;}
.drawer-overlay.open{opacity:1;visibility:visible;}
.drawer{position:fixed;top:0;left:-360px;width:88%;max-width:330px;height:100%;background:var(--cream);border-right:3px solid var(--dark-green);z-index:100;transition:left .24s ease;overflow-y:auto;padding:18px 20px 40px;}
.drawer.open{left:0;}
.drawer .dhead{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;}
.drawer .dhead .brand .name{font-size:20px;}
.drawer .dclose{width:42px;height:42px;border:2.5px solid var(--dark-green);border-radius:12px;background:#fff;box-shadow:3px 3px 0 var(--dark-green);cursor:pointer;display:grid;place-items:center;color:var(--dark-green);}
.drawer .dclose .icon{width:22px;height:22px;}
.drawer a.dlink{font-family:var(--ff-ui);font-weight:600;font-size:17px;color:var(--dark-green);padding:13px 4px;border-bottom:1px solid rgba(45,80,22,.12);display:block;}
.drawer a.dlink.active{color:var(--coral);}
.drawer .dgroup{font-family:var(--ff-ui);font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--coral);padding:16px 4px 6px;}
.drawer .dsub{font-family:var(--ff-body);font-weight:500;font-size:14.5px;color:var(--charcoal);padding:9px 4px 9px 16px;display:block;}
.drawer .dsub:hover{color:var(--dark-green);}
.drawer .post-only{display:none !important;}
body.logged-in .drawer .post-only{display:block !important;}
.drawer .dactions{margin-top:22px;}
.drawer .signin{display:block;}
body.logged-in .drawer .signin{display:none;}

/* ===== Footer ===== */
footer{background:var(--dark-green);color:rgba(255,249,230,.78);padding:60px 0 26px;}
.foot-main{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;margin-bottom:40px;}
.foot-brand .row{display:flex;align-items:center;gap:10px;}
.foot-brand .lock{display:flex;flex-direction:column;line-height:1;}
.foot-brand .name{font-family:var(--ff-ui);font-weight:800;font-size:24px;color:var(--cream);letter-spacing:.04em;line-height:1;}
.foot-brand .tag{font-family:var(--ff-ui);font-weight:500;font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--pineapple-yellow);margin-top:3px;background:none;border:none;padding:0;border-radius:0;}
.foot-brand .desc{font-size:14.5px;line-height:1.6;max-width:380px;margin:16px 0 18px;}
.socials{display:flex;gap:10px;margin-bottom:16px;}
.socials a{width:40px;height:40px;border-radius:11px;border:2px solid rgba(255,249,230,.25);display:grid;place-items:center;color:var(--cream);transition:transform .2s ease,background .2s ease,border-color .2s ease;}
.socials a:hover{background:var(--pineapple-yellow);color:var(--dark-green);border-color:var(--pineapple-yellow);transform:translateY(-2px);}
.socials a .icon{width:19px;height:19px;}
.foot-news{background:rgba(255,249,230,.06);border:1px solid rgba(255,249,230,.14);border-radius:20px;padding:30px;align-self:start;}
.foot-news h4{font-family:var(--ff-ui);font-weight:700;font-size:19px;color:var(--cream);margin-bottom:8px;line-height:1.25;}
.foot-news p{font-size:14px;margin-bottom:18px;}
.news-form{display:flex;gap:10px;flex-wrap:wrap;}
.news-form input{flex:1;min-width:160px;background:var(--cream);border:2px solid var(--dark-green);border-radius:100px;padding:12px 18px;font-size:14px;color:var(--charcoal);outline:none;}
.foot-bottom{border-top:1px solid rgba(255,249,230,.14);padding-top:22px;font-size:13px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:6px 14px;}
.foot-bottom span{display:inline-flex;align-items:center;gap:6px;}
.foot-bottom a{display:inline !important;color:rgba(255,249,230,.78);}.foot-bottom a:hover{color:var(--pineapple-yellow);}

/* itineraries: browse / saved template cards -> Concept 3 sticker cards */
.template-card{background:var(--white);border:3px solid var(--dark-green) !important;border-radius:20px !important;box-shadow:6px 6px 0 var(--dark-green) !important;overflow:hidden;transition:transform .18s ease, box-shadow .18s ease;}
.template-card:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--dark-green) !important;}
.template-card-image{height:130px;}
.template-card-body{padding:18px 20px;}
.template-card-body .destination-label{font-family:var(--ff-ui);font-weight:700;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--coral);}
.template-card-body h3{font-family:var(--ff-display);font-weight:800;font-size:19px;color:var(--leaf-green);margin:4px 0 6px;line-height:1.15;}
.template-card-body p{font-size:14px;color:var(--charcoal);line-height:1.5;}
.template-meta{display:flex;gap:16px;margin-top:12px;font-size:13px;color:var(--black-coral);}
.template-meta ion-icon{vertical-align:middle;margin-right:3px;}

/* itineraries: search/filter controls + continent tabs -> Concept 3 sticker treatment */
.search-box input,
.filter-select{border:2.5px solid var(--dark-green) !important;border-radius:14px !important;box-shadow:4px 4px 0 var(--dark-green) !important;transition:transform .18s ease, box-shadow .18s ease;}
.search-box input:focus,
.filter-select:focus{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--dark-green) !important;border-color:var(--dark-green) !important;}
.filter-tab{border:2.5px solid var(--dark-green) !important;border-radius:100px !important;box-shadow:3px 3px 0 var(--dark-green) !important;font-family:var(--ff-ui);transition:transform .18s ease, box-shadow .18s ease, background .2s ease;}
.filter-tab:hover{border-color:var(--dark-green) !important;color:var(--dark-green);transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--dark-green) !important;}
.filter-tab.active{background:var(--leaf-green) !important;border-color:var(--dark-green) !important;color:var(--cream) !important;box-shadow:3px 3px 0 var(--dark-green) !important;}

/* itinerary day: breathing room between the Est. travel time banner and the map/calendar buttons */
.travel-eta-banner{margin-bottom:10px;}
.day-map-actions{margin-top:14px;}

/* generated itinerary: consolidated, consistent action buttons.
   NOTE: assets/css/style.css also defines #itinerary-result .result-actions
   / .result-action-btn (structural: grid layout, responsive sizing). The
   "sticker" look below (border/shadow/pill radius) intentionally wins on
   .result-action-btn because this file loads after style.css and both
   rules share specificity (0,1,0) — don't re-add a bare `.result-actions`
   or `.result-action-btn` display/layout rule to style.css, or this will
   silently flip back depending on <link> order. */
.result-action-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--ff-ui);font-weight:700;border:2.5px solid var(--dark-green);border-radius:100px;background:var(--white);color:var(--dark-green);box-shadow:3px 3px 0 var(--dark-green);padding:11px 20px;transition:transform .15s ease, box-shadow .15s ease;}
.result-action-btn:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--dark-green);}
.result-action-btn ion-icon{font-size:18px;}
.result-action-btn.result-action-delete{color:var(--coral);border-color:var(--coral);box-shadow:3px 3px 0 var(--coral);}
.result-action-btn.result-action-delete:hover{box-shadow:5px 5px 0 var(--coral);}

/* page modals (email itinerary, etc.) -> Concept 3 sticker modal */
.modal-content{border:3px solid var(--dark-green) !important;border-radius:22px !important;box-shadow:8px 8px 0 var(--dark-green) !important;}
.modal-header h3{font-family:var(--ff-display);font-weight:800;color:var(--leaf-green);letter-spacing:-.01em;}
.modal-footer{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap;}
.modal-footer .btn{width:auto;}

/* generator quiz: keep every field inside the card on small screens */
@media(max-width:600px){
  .generator-form{overflow-x:hidden;}
  .generator-form .form-group input,
  .generator-form .form-group select,
  .generator-form .form-group textarea,
  .generator-form .dest-input-wrapper,
  .generator-form .dest-chip-container,
  .generator-form .dest-typing-input,
  .generator-form .dest-autocomplete-list{width:100%;max-width:100%;box-sizing:border-box;}
  .generator-form .dest-chip-container{flex-wrap:wrap;}
}
@media(max-width:780px){.foot-main{grid-template-columns:1fr;gap:30px;}}

/* ===== Home: hero / marquee / pillars / facts / cta ===== */
.hero{position:relative;overflow:hidden;padding:70px 0 80px;background:radial-gradient(circle at 75% 20%,var(--light-yellow),var(--cream) 60%);}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:center;}
.hero h1{font-family:var(--ff-display);font-weight:800;font-size:clamp(48px,7.5vw,96px);line-height:.94;letter-spacing:-.03em;color:var(--leaf-green);}
.hero h1 .hl{color:var(--coral);}
.hero .lede{font-size:19px;color:var(--charcoal);max-width:470px;margin:28px 0 32px;}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;}
.hero-stage{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;min-height:480px;}
.globe-card{position:relative;width:100%;max-width:440px;height:400px;}
#heroGlobe{position:absolute;inset:0;}
#heroGlobe canvas{display:block;background:transparent;}
.fact-bubble{position:relative;z-index:6;width:100%;max-width:380px;background:var(--white);border:3px solid var(--dark-green);border-radius:20px;padding:14px 20px;box-shadow:5px 5px 0 var(--dark-green);transition:opacity .4s ease;}
.fact-bubble .badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--ff-ui);font-weight:700;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--coral);margin-bottom:5px;}
.fact-bubble .badge .icon{width:13px;height:13px;}
.fact-bubble .txt{font-size:13.5px;font-weight:500;color:var(--charcoal);line-height:1.5;min-height:44px;}
@media(max-width:860px){.hero .wrap{grid-template-columns:1fr;}.hero{padding-top:48px;}.hero-stage{min-height:auto;margin-top:24px;}.globe-card{height:380px;max-width:380px;}.fact-bubble{max-width:100%;}}

.marquee{background:var(--dark-green);color:var(--pineapple-yellow);padding:14px 0;overflow:hidden;}
.marquee-track{display:flex;width:max-content;animation:slide 36s linear infinite;}
.marquee-group{display:flex;align-items:center;gap:26px;padding-right:26px;font-family:var(--ff-ui);font-weight:700;font-size:16px;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;}
.marquee-group .t{flex-shrink:0;}
.marquee-group .dot{width:8px;height:8px;border-radius:50%;background:var(--coral);flex-shrink:0;}
@keyframes slide{from{transform:translateX(0);}to{transform:translateX(-50%);}}

.pillars{padding:40px 0 100px;}
.pillars .head{text-align:center;margin-bottom:52px;}
.pillars .head h2{font-family:var(--ff-display);font-weight:800;font-size:clamp(32px,4.5vw,52px);color:var(--leaf-green);letter-spacing:-.02em;margin-top:12px;}
.pillars .head .kick{font-family:var(--ff-ui);font-weight:700;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--coral);}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.pcard{background:var(--white);border:3px solid var(--dark-green);border-radius:24px;padding:32px 28px;box-shadow:6px 6px 0 var(--dark-green);transition:transform .18s ease,box-shadow .18s ease;}
.pcard:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--dark-green);}
.pcard:nth-child(1){background:var(--light-yellow);}
.pcard:nth-child(3){background:var(--leaf-green);color:var(--cream);}
.pcard:nth-child(3) h3{color:var(--white);}.pcard:nth-child(3) p{color:rgba(255,249,230,.85);}
.pcard:nth-child(3) .ico{background:var(--pineapple-yellow);color:var(--dark-green);border-color:var(--dark-green);}
.pcard .ico{width:56px;height:56px;border-radius:16px;background:var(--pineapple-yellow);border:2.5px solid var(--dark-green);display:grid;place-items:center;margin-bottom:18px;color:var(--dark-green);}
.pcard .ico .icon{width:28px;height:28px;}
.pcard h3{font-family:var(--ff-display);font-weight:800;font-size:23px;color:var(--leaf-green);margin-bottom:10px;letter-spacing:-.01em;}
.pcard p{font-size:15.5px;line-height:1.6;color:var(--charcoal);}
.pcard:nth-child(1) p{color:var(--charcoal);}
@media(max-width:860px){.pgrid{grid-template-columns:1fr;}}

.cta{padding:30px 0 110px;}
.cta .panel{background:var(--leaf-green);border:3px solid var(--dark-green);border-radius:34px;padding:60px 40px;text-align:center;position:relative;overflow:hidden;box-shadow:10px 10px 0 rgba(26,48,9,.25);}
.cta .panel .cta-badge{width:150px;height:150px;border-radius:50%;overflow:hidden;box-shadow:0 8px 32px rgba(45,80,22,.18);margin:0 auto 22px;position:relative;z-index:2;}
.cta .panel .cta-badge img{position:absolute;left:50%;top:50%;width:170%;height:170%;transform:translate(-50%,-50%);object-fit:cover;}
.cta h2{font-family:var(--ff-display);font-weight:800;font-size:clamp(34px,5vw,56px);color:var(--cream);letter-spacing:-.02em;line-height:1.02;position:relative;z-index:2;}
.cta h2 .gold{color:var(--pineapple-yellow);}
.cta p{color:rgba(255,249,230,.88);font-size:18px;margin:16px auto 30px;max-width:420px;position:relative;z-index:2;}
.cta .panel .btn{position:relative;z-index:2;}
.cta .panel::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,transparent 0 26px,rgba(244,211,94,.07) 26px 28px),repeating-linear-gradient(-45deg,transparent 0 26px,rgba(244,211,94,.07) 26px 28px);}

/* ===== Shared sub-page utilities ===== */
.page-hero{padding:60px 0 34px;background:radial-gradient(circle at 80% 8%,var(--light-yellow),var(--cream) 62%);text-align:center;}
.page-hero .kick{font-family:var(--ff-ui);font-weight:700;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--coral);}
.page-hero h1{font-family:var(--ff-display);font-weight:800;font-size:clamp(36px,5.5vw,66px);letter-spacing:-.03em;color:var(--leaf-green);line-height:1;margin:12px 0 14px;}
.page-hero h1 .hl{color:var(--coral);}
.page-hero .lead{font-size:18px;color:var(--charcoal);max-width:620px;margin:0 auto;}
.section{padding:58px 0;}
.section.alt{background:var(--light-yellow);}
.section-head{text-align:center;margin-bottom:40px;}
.section-head .kick{font-family:var(--ff-ui);font-weight:700;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--coral);}
.section-head h2{font-family:var(--ff-display);font-weight:800;font-size:clamp(28px,4vw,44px);color:var(--leaf-green);letter-spacing:-.02em;margin-top:10px;}
.scard{background:var(--white);border:3px solid var(--dark-green);border-radius:22px;padding:28px;box-shadow:6px 6px 0 var(--dark-green);}
.scard .ico{width:52px;height:52px;border-radius:14px;background:var(--pineapple-yellow);border:2.5px solid var(--dark-green);display:grid;place-items:center;margin-bottom:16px;color:var(--dark-green);}
.scard .ico .icon{width:26px;height:26px;}
.scard h3{font-family:var(--ff-display);font-weight:800;font-size:20px;color:var(--leaf-green);margin-bottom:8px;}
.scard p{font-size:15px;color:var(--charcoal);line-height:1.6;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
@media(max-width:860px){.grid-2,.grid-3{grid-template-columns:1fr;}}

/* pricing (mockup price-card grid, unused on the real site) */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:start;}
.price-card .billnote{font-size:12.5px;font-weight:600;color:var(--leaf-green);margin-top:6px;min-height:18px;}
.price-card.featured .billnote{color:var(--pineapple-yellow);}
.price-card{background:var(--white);border:3px solid var(--dark-green);border-radius:24px;padding:32px 26px;box-shadow:6px 6px 0 var(--dark-green);position:relative;}
.price-card.featured{background:var(--leaf-green);color:var(--cream);}
.price-card.featured h3,.price-card.featured .price{color:var(--white);}
.price-card .flag{position:absolute;top:-15px;left:50%;transform:translateX(-50%);background:var(--pineapple-yellow);border:2px solid var(--dark-green);border-radius:100px;padding:5px 16px;font-family:var(--ff-ui);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--dark-green);white-space:nowrap;box-shadow:2px 2px 0 var(--dark-green);}
.price-card h3{font-family:var(--ff-display);font-weight:800;font-size:22px;color:var(--leaf-green);}
.price-card .price{font-family:var(--ff-display);font-weight:800;font-size:42px;color:var(--leaf-green);letter-spacing:-.02em;margin:8px 0 2px;}
.price-card .price small{font-size:15px;font-weight:600;color:var(--black-coral);}
.price-card.featured .price small{color:rgba(255,249,230,.7);}
.price-card .sub{font-size:13.5px;color:var(--black-coral);margin-bottom:6px;}
.price-card.featured .sub{color:rgba(255,249,230,.75);}
.price-card .feat{list-style:none;margin:18px 0 24px;display:flex;flex-direction:column;gap:11px;}
.price-card .feat li{display:flex;gap:9px;align-items:flex-start;font-size:14px;color:var(--charcoal);}
.price-card.featured .feat li{color:rgba(255,249,230,.92);}
.price-card .feat .icon{width:17px;height:17px;color:var(--leaf-green);flex-shrink:0;margin-top:2px;}
.price-card.featured .feat .icon{color:var(--pineapple-yellow);}
.price-card .btn{width:100%;justify-content:center;}
@media(max-width:860px){.price-grid{grid-template-columns:1fr;}}

/* faq accordion */
.faq{max-width:760px;margin:0 auto;}
.faq details{background:var(--white);border:2.5px solid var(--dark-green);border-radius:16px;box-shadow:4px 4px 0 var(--dark-green);margin-bottom:14px;}
.faq summary{list-style:none;cursor:pointer;font-family:var(--ff-ui);font-weight:700;font-size:16px;color:var(--leaf-green);padding:16px 18px;display:flex;justify-content:space-between;align-items:center;gap:12px;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary .pl{font-size:22px;line-height:1;transition:transform .2s ease;flex-shrink:0;color:var(--coral);}
.faq details[open] summary .pl{transform:rotate(45deg);}
.faq .ans{padding:0 18px 18px;font-size:15px;color:var(--charcoal);line-height:1.65;}

/* tabs (planning) */
.tabs{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:30px;}
.tab{font-family:var(--ff-ui);font-weight:700;font-size:14px;padding:11px 20px;border-radius:100px;border:2.5px solid var(--dark-green);background:var(--white);color:var(--dark-green);cursor:pointer;box-shadow:3px 3px 0 var(--dark-green);transition:transform .15s ease;}
.tab:hover{transform:translate(-1px,-1px);}
.tab.on{background:var(--pineapple-yellow);}
/* on phones, a clean 2x2 grid (all tabs visible, no horizontal scrolling) */
@media(max-width:600px){
  .tabs{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
  .tab{width:100%;text-align:center;justify-content:center;padding:12px 10px;font-size:13.5px;}
}
.tabpanel{display:none;}
.tabpanel.on{display:block;}

/* profile */
.profile-head{display:flex;align-items:center;gap:22px;flex-wrap:wrap;}
.profile-avatar{width:96px;height:96px;border-radius:50%;overflow:hidden;border:3px solid var(--dark-green);box-shadow:4px 4px 0 var(--dark-green);position:relative;flex-shrink:0;}
.profile-avatar img{position:absolute;left:50%;top:50%;width:170%;height:170%;transform:translate(-50%,-50%);object-fit:cover;}
.tier-badge{display:inline-flex;align-items:center;gap:6px;background:var(--pineapple-yellow);border:2px solid var(--dark-green);border-radius:100px;padding:4px 12px;font-family:var(--ff-ui);font-weight:700;font-size:12px;color:var(--dark-green);}
.field{margin-bottom:16px;}
.field label{display:block;font-family:var(--ff-ui);font-weight:600;font-size:13px;color:var(--leaf-green);margin-bottom:6px;}
.field input,.field select{width:100%;background:var(--white);border:2px solid var(--dark-green);border-radius:100px;padding:12px 16px;font-size:14px;color:var(--charcoal);outline:none;}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s cubic-bezier(.2,.7,.2,1),transform .6s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}

/* auth modal: keep checkbox + label on one line, inputs full width */
.auth-modal .remember-me-label{display:inline-flex !important;align-items:center;gap:14px;cursor:pointer;margin:0;}
.auth-modal .remember-me-label input[type="checkbox"]{width:18px;height:18px;margin:0;flex:0 0 18px;}
.auth-modal .remember-me-label span{display:inline;}
.auth-modal input[type="email"],.auth-modal input[type="password"],.auth-modal input[type="text"]{width:100%;}
.auth-modal .form-group label{display:block;}

/* ===== Pricing page re-skin (real markup + pricing.js kept) ===== */
.page-subtitle{font-size:18px;color:var(--black-coral);text-align:center;max-width:560px;margin:10px auto 0;}

/* billing toggle: centered, on-brand, well-spaced */
.billing-toggle{display:flex;align-items:center;justify-content:center;gap:18px;width:fit-content;margin:0 auto 10px !important;font-family:var(--ff-ui);font-weight:700;font-size:16px;}
.billing-toggle span{color:var(--black-coral) !important;font-weight:600;display:inline-flex;align-items:center;}
.billing-toggle span.active{color:var(--leaf-green) !important;}
.billing-toggle .toggle-switch{width:56px;height:30px;background:var(--white) !important;border:2.5px solid var(--dark-green) !important;border-radius:100px;box-shadow:2px 2px 0 var(--dark-green);flex-shrink:0;}
.billing-toggle .toggle-switch.active{background:var(--pineapple-yellow) !important;}
.billing-toggle .toggle-switch::after{background:var(--dark-green) !important;width:20px;height:20px;top:3px;left:3px;}
.billing-toggle .toggle-switch.active::after{transform:translateX(26px);}
.billing-toggle .save-badge{display:inline-block;background:var(--coral) !important;color:#fff !important;font-size:12.5px;font-weight:700;padding:4px 12px;border-radius:100px;margin-left:8px;text-transform:none;letter-spacing:.01em;white-space:nowrap;}
#student-toggle-row{margin:10px 0 34px !important;}

/* tier cards: consistent light sticker cards, clear green checks */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch;max-width:1100px;margin:0 auto;}
.pricing-card{background:var(--white);border:3px solid var(--dark-green) !important;border-radius:24px !important;box-shadow:6px 6px 0 var(--dark-green) !important;padding:32px 26px;position:relative;display:flex;flex-direction:column;}
#premium-card{background:var(--light-yellow);}
#premium-card::before{content:"Most popular";position:absolute;top:-15px;left:50%;transform:translateX(-50%);background:var(--coral);color:#fff;font-family:var(--ff-ui);font-weight:700;font-size:11px;letter-spacing:.07em;text-transform:uppercase;padding:5px 16px;border-radius:100px;border:2px solid var(--dark-green);white-space:nowrap;}
#premium-card .pricing-card-logo,#platinum-card .pricing-card-logo{display:none !important;}
.pricing-card h3{font-family:var(--ff-display);font-weight:800;font-size:22px;color:var(--leaf-green);margin-bottom:4px;text-align:center;}
.pricing-card .price{font-family:var(--ff-display);font-weight:800;font-size:42px;color:var(--leaf-green);letter-spacing:-.02em;line-height:1;margin:6px 0 2px;text-align:center;}
.pricing-card .price-period{font-size:13.5px;color:var(--black-coral);margin-bottom:18px;text-align:center;}
.features-list{list-style:none;display:flex;flex-direction:column;gap:11px;margin:14px 0 22px;text-align:left;padding:0;}
.features-list li{display:flex;align-items:flex-start;gap:10px;font-size:15px;line-height:1.5;color:var(--charcoal);}
.feat-check{color:var(--leaf-green) !important;font-weight:900;flex:0 0 auto;background:none !important;border:none !important;width:auto !important;height:auto !important;font-size:15px;line-height:1.4;padding:0 !important;}
.feat-x{color:var(--coral) !important;font-weight:900;flex:0 0 auto;background:none !important;border:none !important;width:auto !important;height:auto !important;font-size:15px;line-height:1.4;padding:0 !important;}
.feat-label{display:inline;}
.feat-no{display:inline;color:var(--black-coral);}
.pricing-card .pricing-card-btn-wrap{margin-top:auto;}
.pricing-card .pricing-card-btn-wrap .btn{width:100%;justify-content:center;}
/* Crown card: light with a gold accent, keeps its crown emoji */
#crown-card{background:var(--light-yellow);border-color:var(--pineapple-gold) !important;box-shadow:6px 6px 0 var(--pineapple-gold) !important;}
@media(max-width:860px){.pricing-grid{grid-template-columns:1fr;}}
/* pricing FAQ accordion -> Concept 3 sticker accordion */
.pricing-faq{max-width:760px;margin:60px auto 0;}
.pricing-faq h2{font-family:var(--ff-display);font-weight:800;color:var(--leaf-green);text-align:center;font-size:clamp(28px,4vw,40px);letter-spacing:-.02em;margin-bottom:24px;}
.pricing-faq .faq-item{background:var(--white) !important;border:2.5px solid var(--dark-green) !important;border-radius:16px !important;box-shadow:4px 4px 0 var(--dark-green) !important;margin-bottom:14px !important;padding:0 !important;}
.pricing-faq .faq-item summary{font-family:var(--ff-ui);font-weight:700;font-size:16px;color:var(--leaf-green) !important;padding:16px 18px !important;}
.pricing-faq .faq-item summary::after{color:var(--coral) !important;}
.pricing-faq .faq-item p{font-size:15px;line-height:1.6;color:var(--charcoal) !important;padding:0 18px;}

/* ===== Auth modal (injected by concept3.js on every page; self-contained) ===== */
@keyframes modal-in{from{opacity:0;transform:scale(.94) translateY(8px);}to{opacity:1;transform:scale(1) translateY(0);}}
@keyframes backdrop-in{from{opacity:0;}to{opacity:1;}}
.auth-modal{display:none;position:fixed;z-index:9999;inset:0;background:rgba(0,0,0,.7);}
.auth-modal.active{display:flex;align-items:center;justify-content:center;animation:backdrop-in .2s ease;}
.auth-modal.active .auth-modal-content{animation:modal-in .25s cubic-bezier(.34,1.3,.64,1) both;}
.auth-modal-content{background:var(--white);padding:42px 34px;border-radius:20px;max-width:450px;width:90%;position:relative;box-shadow:0 24px 64px rgba(0,0,0,.22),0 4px 16px rgba(0,0,0,.1);max-height:92vh;overflow-y:auto;}
.auth-modal-close{position:absolute;top:14px;right:14px;font-size:28px;background:none;border:none;color:var(--charcoal);cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;}
.auth-modal-close:hover{background:#f0f0f0;}
.auth-modal-title{font-family:var(--ff-ui);font-weight:800;font-size:22px;color:var(--leaf-green);margin-bottom:8px;text-align:center;}
.auth-modal-text{color:var(--black-coral);text-align:center;margin-bottom:22px;font-size:14px;}
.auth-form .form-group{margin-bottom:18px;}
.auth-form label{display:block;font-family:var(--ff-ui);font-weight:600;color:var(--leaf-green);margin-bottom:6px;font-size:13px;}
.auth-form input{width:100%;padding:12px 16px;border:2px solid var(--dark-green);border-radius:100px;font-size:14px;outline:none;color:var(--charcoal);background:#FBF7E8;}
.auth-form input::placeholder{color:#8a8f98;}
.auth-form input:focus{border-color:var(--coral);background:var(--white);box-shadow:0 0 0 3px rgba(232,115,74,.15);}
.auth-form .btn-full{width:100%;margin-top:8px;justify-content:center;}
.auth-register-link{text-align:center;margin-top:18px;font-size:13.5px;color:var(--black-coral);}
.auth-register-link a,.auth-modal-content a{display:inline;color:var(--coral);font-weight:600;}
.social-login-buttons{display:flex;flex-direction:column;gap:12px;margin:18px 0 4px;}
.btn-social{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:12px 20px;border-radius:100px;font-family:var(--ff-ui);font-size:14px;font-weight:600;cursor:pointer;border:2px solid var(--dark-green);background:var(--white);color:var(--charcoal);}
.btn-social:hover{background:var(--light-yellow);}
.btn-social svg{flex-shrink:0;}
.auth-divider{display:flex;align-items:center;margin:20px 0;}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:#dcdcdc;}
.auth-divider span{padding:0 14px;font-size:12px;color:var(--black-coral);white-space:nowrap;}
