@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&family=DM+Sans:wght@300;400;500;600&display=swap');

/* ── Variables ── */
:root{
  --green:#2D6A4F;--green-mid:#40916C;--green-light:#52B788;
  --green-pale:#D8F3DC;--green-xpale:#f0faf3;
  --amber:#E76F51;--dark:#1B1B2F;--dark2:#2C2C3E;
  --text:#2d3436;--muted:#636e72;--border:#e4e8e0;
  --surface:#F6F8F3;--danger:#e74c3c;--warning:#f39c12;
  --radius:14px;--shadow:0 2px 16px rgba(0,0,0,.06);--shadow-md:0 4px 28px rgba(0,0,0,.10);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{font-family:'DM Sans',sans-serif;background:var(--surface);color:var(--text);font-size:15px;line-height:1.6;min-height:100vh;}
h1,h2,h3,h4{font-family:'Playfair Display',serif;line-height:1.2;}
a{color:var(--green);text-decoration:none;}
button,input,select,textarea{font-family:'DM Sans',sans-serif;-webkit-appearance:none;}
img{max-width:100%;height:auto;display:block;}
ul{list-style:none;}
.container{max-width:1100px;margin:0 auto;padding:0 20px;}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px 24px;border:none;border-radius:100px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;line-height:1;white-space:nowrap;touch-action:manipulation;}
.btn-primary{background:var(--green-light);color:#fff;}
.btn-primary:hover,.btn-primary:active{background:var(--green-mid);color:#fff;}
.btn-dark{background:var(--dark);color:#fff;}
.btn-outline{background:transparent;color:var(--green);border:1.5px solid var(--green-light);}
.btn-outline:hover{background:var(--green-pale);}
.btn-ghost{background:transparent;color:var(--muted);border:1.5px solid var(--border);}
.btn-ghost:hover{border-color:var(--green-light);color:var(--green);}
.btn-danger{background:#ffeaea;color:var(--danger);border:none;}
.btn-full{width:100%;border-radius:10px;padding:13px;}
.btn-sm{padding:8px 16px;font-size:13px;border-radius:8px;}
.btn-xs{padding:5px 12px;font-size:12px;border-radius:6px;}
.btn:disabled{opacity:.55;cursor:not-allowed;}

/* ── Forms ── */
.form-group{margin-bottom:16px;}
.form-group label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:var(--text);}
.form-control{width:100%;padding:12px 15px;border:1.5px solid var(--border);border-radius:10px;font-size:15px;outline:none;transition:border .2s;background:#fff;color:var(--text);}
.form-control:focus{border-color:var(--green-light);}
textarea.form-control{resize:vertical;min-height:90px;line-height:1.6;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
input[type=range]{width:100%;-webkit-appearance:none;height:5px;border-radius:3px;background:var(--border);outline:none;cursor:pointer;margin:8px 0;}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--green);box-shadow:0 2px 8px rgba(45,106,79,.3);}
.alert-error{background:#ffeaea;color:var(--danger);padding:12px 16px;border-radius:8px;font-size:13px;margin-bottom:16px;border:1px solid #ffc0c0;display:none;}
.alert-success{background:var(--green-pale);color:var(--green);padding:12px 16px;border-radius:8px;font-size:13px;margin-bottom:16px;}

/* ── Cards ── */
.card{background:#fff;border-radius:16px;border:1px solid var(--border);padding:20px;margin-bottom:18px;}
.card-title{font-size:15px;font-weight:600;color:var(--dark);margin-bottom:16px;display:flex;align-items:center;gap:8px;font-family:'DM Sans',sans-serif;flex-wrap:wrap;}
.card-title small{font-size:12px;color:var(--muted);font-weight:400;margin-left:auto;}

/* ── Tags ── */
.tag{display:inline-block;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:600;}
.tag-green{background:var(--green-pale);color:var(--green);}
.tag-amber{background:#fff4e6;color:#c0592b;}
.tag-blue{background:#e8f4fd;color:#1a6a9a;}
.tag-gray{background:#f0f0ee;color:var(--muted);}
.tag-red{background:#ffeaea;color:var(--danger);}
.pill{display:inline-block;padding:4px 12px;border-radius:100px;font-size:12px;font-weight:600;}
.pill-free{background:#f0f0ee;color:var(--muted);}
.pill-basic{background:#e8f4fd;color:#1a6a9a;}
.pill-pro{background:var(--green-pale);color:var(--green);}
.pill-elite{background:#fff4e6;color:#c0592b;}
.pill-corporate{background:#f3e8ff;color:#7c3aed;}
.pill-active{background:var(--green-pale);color:var(--green);}
.pill-pending{background:#fff4e6;color:#c0592b;}
.pill-failed{background:#ffeaea;color:var(--danger);}

/* ── Progress ── */
.progress-wrap{margin-bottom:14px;}
.progress-label{display:flex;justify-content:space-between;font-size:13px;margin-bottom:5px;}
.progress-bar{height:7px;background:var(--border);border-radius:100px;overflow:hidden;}
.progress-fill{height:100%;border-radius:100px;background:linear-gradient(90deg,var(--green),var(--green-light));transition:width .8s ease;}

/* ── Toast ── */
#wp-toast{position:fixed;bottom:20px;right:16px;left:16px;max-width:360px;margin:0 auto;padding:14px 18px;border-radius:12px;font-size:14px;font-weight:500;z-index:99999;transform:translateY(80px);opacity:0;transition:all .3s;box-shadow:var(--shadow-md);pointer-events:none;text-align:center;}
#wp-toast.show{transform:translateY(0);opacity:1;}
#wp-toast.success{background:var(--green);color:#fff;}
#wp-toast.error{background:var(--danger);color:#fff;}
#wp-toast.info{background:var(--dark);color:#fff;}
#wp-toast.warning{background:var(--warning);color:#fff;}

/* ── Modal ── */
.wp-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:10000;display:flex;align-items:flex-end;justify-content:center;padding:0;}
.wp-modal{background:#fff;border-radius:20px 20px 0 0;padding:24px 20px;width:100%;position:relative;max-height:92vh;overflow-y:auto;box-shadow:0 -4px 30px rgba(0,0,0,.15);}
.wp-modal-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:22px;color:var(--muted);cursor:pointer;line-height:1;padding:4px;}

/* ── HEADER ── */
#site-header{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:500;}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:60px;}
.site-logo{font-family:'Playfair Display',serif;font-size:22px;color:var(--green);font-weight:700;}
.header-nav{display:flex;align-items:center;gap:6px;}
.header-nav a{font-size:14px;font-weight:500;color:var(--muted);padding:6px 12px;border-radius:8px;transition:all .2s;}
.header-nav a:hover{color:var(--green);background:var(--green-xpale);}

/* ── HERO ── */
.hero-section{background:linear-gradient(135deg,var(--dark) 0%,#1a2838 50%,#102820 100%);min-height:85vh;display:flex;align-items:center;padding:50px 0;}
.hero-content{max-width:680px;margin:0 auto;text-align:center;padding:0 4px;}
.hero-badge{display:inline-block;background:rgba(82,183,136,.15);color:var(--green-light);border:1px solid rgba(82,183,136,.25);border-radius:100px;padding:5px 16px;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:20px;}
.hero-title{font-size:clamp(32px,8vw,64px);color:#fff;line-height:1.08;margin-bottom:18px;}
.hero-title span{color:var(--green-light);}
.hero-sub{color:rgba(255,255,255,.6);font-size:clamp(15px,4vw,17px);max-width:500px;margin:0 auto 36px;}
.hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:48px;}
.hero-chips{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;}
.hero-chip{display:flex;align-items:center;gap:7px;color:rgba(255,255,255,.4);font-size:13px;}
.hero-chip-dot{width:6px;height:6px;border-radius:50%;background:var(--green-light);}

/* ── Sections ── */
.section-pad{padding:60px 0;}
.bg-white{background:#fff;}
.bg-surface{background:var(--surface);}
.section-kicker{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--green);font-weight:600;margin-bottom:10px;}
.section-title{font-size:clamp(22px,5vw,38px);color:var(--dark);margin-bottom:14px;}
.section-sub{font-size:16px;color:var(--muted);max-width:540px;}

/* ── Steps grid ── */
.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;margin-top:40px;}
.step-card{text-align:center;padding:24px 16px;}
.step-num{width:46px;height:46px;background:var(--green-pale);color:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;margin:0 auto 14px;}
.step-card h3{font-size:15px;font-weight:600;margin-bottom:8px;font-family:'DM Sans',sans-serif;color:var(--dark);}
.step-card p{font-size:14px;color:var(--muted);}

/* ── Programs ── */
.programs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-top:40px;}
.prog-card{background:#fff;border-radius:16px;border:1px solid var(--border);padding:22px;transition:all .2s;}
.prog-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.prog-icon{font-size:30px;margin-bottom:10px;}
.prog-name{font-size:16px;font-weight:700;color:var(--dark);margin-bottom:8px;font-family:'DM Sans',sans-serif;}
.prog-desc{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:12px;}
.prog-footer{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--muted);}

/* ── Pricing ── */
.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(175px,1fr));gap:14px;margin-top:40px;}
.plan-card{background:#fff;border:1.5px solid var(--border);border-radius:16px;padding:20px 18px;transition:all .2s;}
.plan-card.featured{border-color:var(--green);background:var(--green-xpale);}
.plan-badge{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--green);margin-bottom:8px;}
.plan-name{font-size:17px;font-weight:700;color:var(--dark);margin-bottom:4px;font-family:'DM Sans',sans-serif;}
.plan-price{font-size:26px;font-weight:700;color:var(--green);margin-bottom:4px;font-family:'DM Sans',sans-serif;}
.plan-price small{font-size:13px;font-weight:400;color:var(--muted);}
.plan-desc{font-size:13px;color:var(--muted);margin-bottom:12px;line-height:1.5;}
.plan-features{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;}
.plan-features li{font-size:13px;display:flex;align-items:flex-start;gap:7px;}
.plan-features li::before{content:'✓';color:var(--green);font-weight:700;flex-shrink:0;}

/* ── Testimonials ── */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-top:40px;}
.testi-card{background:#fff;border-radius:16px;border:1px solid var(--border);padding:22px;}
.testi-body{font-size:15px;line-height:1.7;color:var(--text);margin-bottom:14px;font-style:italic;}
.testi-author{display:flex;align-items:center;gap:12px;}
.testi-avatar{width:38px;height:38px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0;}

/* ── FAQ ── */
.faq-list{margin-top:36px;display:flex;flex-direction:column;gap:10px;max-width:720px;}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden;}
.faq-q{padding:15px 18px;font-weight:600;font-size:15px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:10px;}
.faq-q:hover{background:var(--green-xpale);}
.faq-icon{font-size:18px;color:var(--muted);flex-shrink:0;transition:transform .2s;}
.faq-item.open .faq-icon{transform:rotate(45deg);}
.faq-a{padding:0 18px 14px;font-size:14px;color:var(--muted);line-height:1.7;display:none;}
.faq-item.open .faq-a{display:block;}

/* ── Footer ── */
#site-footer{background:var(--dark);color:rgba(255,255,255,.5);padding:48px 0 24px;}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px;}
.footer-logo{font-family:'Playfair Display',serif;font-size:22px;color:#fff;display:block;margin-bottom:12px;}
.footer-desc{font-size:14px;line-height:1.7;margin-bottom:14px;}
.footer-col h4{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.6);margin-bottom:14px;}
.footer-col a{display:block;font-size:14px;color:rgba(255,255,255,.4);margin-bottom:9px;transition:color .2s;}
.footer-col a:hover{color:var(--green-light);}
.footer-social{display:flex;gap:10px;margin-top:14px;}
.footer-social a{width:34px;height:34px;background:rgba(255,255,255,.08);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;color:rgba(255,255,255,.5);transition:all .2s;}
.footer-social a:hover{background:var(--green);color:#fff;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-size:13px;}

/* ── Auth page ── */
.auth-page-wrap{min-height:calc(100vh - 60px);display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--surface);}
.auth-card{background:#fff;border-radius:20px;padding:32px 24px;border:1px solid var(--border);box-shadow:var(--shadow);max-width:420px;width:100%;}
.auth-logo{font-size:22px;color:var(--green);margin-bottom:4px;}
.auth-sub{color:var(--muted);font-size:14px;margin-bottom:22px;}
.auth-tabs{display:flex;background:var(--surface);border-radius:10px;padding:4px;margin-bottom:22px;gap:4px;}
.auth-tab{flex:1;padding:9px;border-radius:7px;border:none;background:none;font-size:14px;font-weight:500;color:var(--muted);cursor:pointer;transition:all .2s;}
.auth-tab.active{background:#fff;color:var(--green);box-shadow:0 1px 6px rgba(0,0,0,.07);}

/* ── Onboarding ── */
.ob-outer{background:var(--surface);min-height:100vh;}
.ob-wrap{max-width:620px;margin:0 auto;padding:24px 16px 60px;}
.ob-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;}
.ob-steps{display:flex;gap:5px;margin-bottom:28px;}
.ob-step{flex:1;height:4px;border-radius:100px;background:var(--border);transition:all .3s;}
.ob-step.done{background:var(--green-light);}
.ob-step.active{background:var(--green);}
.step-kicker{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--green);font-weight:600;margin-bottom:6px;}
.step-title{font-size:24px;color:var(--dark);margin-bottom:8px;}
.step-desc{color:var(--muted);font-size:15px;margin-bottom:22px;}
.option-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:22px;}
.option-card{border:2px solid var(--border);border-radius:14px;padding:16px 14px;cursor:pointer;transition:all .2s;background:#fff;}
.option-card:hover{border-color:var(--green-light);}
.option-card.selected{border-color:var(--green);background:var(--green-pale);}
.opt-icon{font-size:24px;margin-bottom:6px;display:block;}
.opt-label{font-size:14px;font-weight:600;}
.opt-desc{font-size:12px;color:var(--muted);margin-top:3px;}
.radio-list{display:flex;flex-direction:column;gap:8px;margin-bottom:18px;}
.radio-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s;background:#fff;}
.radio-item:hover{border-color:var(--green-light);}
.radio-item.selected{border-color:var(--green);background:var(--green-pale);}
.radio-dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;transition:all .2s;}
.radio-item.selected .radio-dot{background:var(--green);border-color:var(--green);}
.ob-nav{display:flex;justify-content:space-between;align-items:center;margin-top:28px;padding-top:18px;border-top:1px solid var(--border);}

/* ══════════════════════════════════════
   DASHBOARD — MOBILE-FIRST LAYOUT
════════════════════════════════════════ */
.dash-outer{display:flex;flex-direction:column;min-height:100vh;}

/* Top bar */
.dash-header{background:#fff;border-bottom:1px solid var(--border);height:58px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;position:sticky;top:0;z-index:200;flex-shrink:0;}
.dash-logo{font-family:'Playfair Display',serif;font-size:19px;color:var(--green);}
.dash-user-info{display:flex;align-items:center;gap:8px;}
.user-name{font-size:13px;font-weight:600;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.user-plan{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;}
.notif-btn{background:none;border:none;font-size:20px;cursor:pointer;position:relative;padding:4px 6px;line-height:1;}
.notif-badge{position:absolute;top:1px;right:1px;width:9px;height:9px;background:var(--amber);border-radius:50%;border:2px solid #fff;}

/* Body layout */
.dash-body{display:flex;flex:1;overflow:hidden;}

/* Sidebar — hidden on mobile, visible on desktop */
.sidebar{width:220px;background:#fff;border-right:1px solid var(--border);padding:16px 10px;flex-shrink:0;display:flex;flex-direction:column;overflow-y:auto;}
.sidebar-section{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);padding:0 10px;margin:14px 0 5px;}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 10px;border-radius:9px;font-size:14px;font-weight:500;color:var(--muted);border:none;background:none;width:100%;text-align:left;cursor:pointer;transition:all .15s;}
.nav-item:hover{background:var(--green-xpale);color:var(--green);}
.nav-item.active{background:var(--green-pale);color:var(--green);}
.nav-icon{font-size:16px;width:22px;text-align:center;flex-shrink:0;}

/* Main content area */
.dash-main{flex:1;overflow-y:auto;padding:20px 16px;min-width:0;}
.dash-page{display:none;}
.dash-page.active{display:block;}
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:10px;}
.page-title{font-size:22px;color:var(--dark);}

/* Stats */
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px;}
.stat-card{background:#fff;border-radius:14px;padding:15px;border:1px solid var(--border);}
.stat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;}
.stat-val{font-size:24px;font-weight:700;color:var(--dark);font-family:'DM Sans',sans-serif;line-height:1;}
.stat-unit{font-size:12px;color:var(--muted);font-weight:400;}
.stat-sub{font-size:12px;color:var(--green);margin-top:4px;}

/* Two column — stacks on mobile */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;}

/* Checklist */
.checklist{list-style:none;}
.check-item{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--border);cursor:pointer;}
.check-item:last-child{border-bottom:none;}
.check-box{width:22px;height:22px;border-radius:6px;border:2px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff;transition:all .15s;}
.check-box.checked{background:var(--green);border-color:var(--green);}
.check-item.done .check-text{text-decoration:line-through;color:var(--muted);}
.check-text{font-size:14px;}

/* Upgrade banner */
.upgrade-banner{background:linear-gradient(135deg,var(--green),var(--green-mid));color:#fff;border-radius:14px;padding:18px 20px;display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap;}
.upgrade-banner h4{font-size:15px;margin-bottom:3px;font-family:'DM Sans',sans-serif;}
.upgrade-banner p{font-size:13px;opacity:.85;}

/* Program cards */
.program-card{border:1.5px solid var(--border);border-radius:14px;padding:16px 18px;margin-bottom:10px;background:#fff;}
.prog-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:6px;flex-wrap:wrap;}
.prog-title{font-size:14px;font-weight:600;}
.locked-msg{font-size:12px;color:var(--amber);display:flex;align-items:center;gap:4px;flex-shrink:0;}

/* Lesson */
.lesson-content{font-size:14px;line-height:1.9;color:var(--text);white-space:pre-wrap;}

/* Mood */
.mood-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;}
.mood-btn{padding:8px 14px;border-radius:100px;border:1.5px solid var(--border);font-size:13px;background:#fff;cursor:pointer;transition:all .15s;}
.mood-btn:hover,.mood-btn.active{border-color:var(--green);background:var(--green-pale);color:var(--green);font-weight:600;}

/* Community */
.post-card{border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:10px;background:#fff;}
.post-meta{font-size:12px;color:var(--muted);margin-bottom:6px;}
.post-content{font-size:14px;line-height:1.7;color:var(--text);word-break:break-word;}
.post-footer{display:flex;gap:12px;margin-top:10px;}
.post-action-btn{background:none;border:1px solid var(--border);border-radius:20px;padding:5px 12px;font-size:13px;cursor:pointer;color:var(--muted);transition:all .15s;display:flex;align-items:center;gap:5px;}
.post-action-btn:hover,.post-action-btn:active{border-color:var(--green);color:var(--green);}
.replies-section{margin-top:12px;border-top:1px solid var(--border);padding-top:12px;}
.replies-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;}
.reply-item{background:var(--surface);border-radius:10px;padding:10px 12px;}
.reply-form{display:flex;gap:8px;align-items:flex-start;}
.reply-form input{flex:1;min-width:0;}

/* Notifications */
.notif-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);cursor:pointer;}
.notif-item:last-child{border-bottom:none;}
.notif-dot{width:9px;height:9px;border-radius:50%;background:var(--green);margin-top:5px;flex-shrink:0;}
.notif-dot.read{background:var(--border);}

/* Messages */
.msg-thread{display:flex;flex-direction:column;gap:10px;padding:4px 0;}
.msg-bubble{max-width:85%;padding:11px 14px;border-radius:12px;font-size:14px;line-height:1.6;word-break:break-word;}
.msg-bubble.sent{background:var(--green);color:#fff;align-self:flex-end;border-bottom-right-radius:4px;}
.msg-bubble.received{background:#fff;border:1px solid var(--border);align-self:flex-start;border-bottom-left-radius:4px;}
.msg-time{font-size:11px;opacity:.65;margin-top:4px;}

/* Streak */
.streak-grid{display:flex;gap:5px;flex-wrap:wrap;margin-top:10px;}
.streak-day{width:34px;height:34px;border-radius:8px;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--muted);flex-shrink:0;}
.streak-day.done{background:var(--green);border-color:var(--green);color:#fff;}
.streak-day.today{border-color:var(--green);color:var(--green);}

/* Tables */
.wp-table{width:100%;border-collapse:collapse;font-size:13px;}
.wp-table th{background:var(--surface);padding:10px 12px;text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:600;white-space:nowrap;}
.wp-table td{padding:11px 12px;border-bottom:1px solid var(--border);vertical-align:middle;word-break:break-word;}
.wp-table tbody tr:last-child td{border-bottom:none;}
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}

/* ── Mobile bottom nav (phones only) ── */
.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);z-index:300;padding:6px 0 max(6px,env(safe-area-inset-bottom));}
.mobile-nav-grid{display:grid;grid-template-columns:repeat(5,1fr);}
.mobile-nav-btn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 4px;background:none;border:none;font-size:10px;font-weight:500;color:var(--muted);cursor:pointer;transition:color .15s;}
.mobile-nav-btn.active{color:var(--green);}
.mobile-nav-btn .icon{font-size:20px;line-height:1;}

/* ══════════════════════════════════════
   RESPONSIVE BREAKPOINTS
════════════════════════════════════════ */

/* ── Tablet (≤768px) ── */
@media(max-width:768px){
  /* Hide desktop sidebar */
  .sidebar{display:none;}
  /* Show mobile bottom nav */
  .mobile-bottom-nav{display:block;}
  /* Add padding so content isn't behind bottom nav */
  .dash-main{padding:16px 14px 80px;}
  /* Header adjustments */
  .dash-header{padding:0 14px;}
  .user-name{max-width:100px;}
  /* Stats 2 columns */
  .stats-grid{grid-template-columns:1fr 1fr;}
  /* Two-col stacks */
  .two-col{grid-template-columns:1fr;}
  /* Form row stacks */
  .form-row{grid-template-columns:1fr;}
  /* Plans single column */
  .plans-grid{grid-template-columns:1fr;}
  /* Programs single column */
  .programs-grid{grid-template-columns:1fr;}
  /* Modal as bottom sheet */
  .wp-modal-overlay{align-items:flex-end;}
  .wp-modal{border-radius:20px 20px 0 0;max-height:88vh;}
  /* Header nav — hide text links, keep buttons */
  .header-nav a:not(.btn){display:none;}
  /* Hero adjustments */
  .hero-section{min-height:auto;padding:50px 0 40px;}
  .hero-btns{flex-direction:column;align-items:center;}
  .hero-btns .btn{width:100%;max-width:280px;}
  /* Footer */
  .footer-inner{grid-template-columns:1fr 1fr;}
  .footer-inner>div:first-child{grid-column:1/-1;}
  /* Option grid stacks */
  .option-grid{grid-template-columns:1fr 1fr;}
  /* Post action buttons */
  .post-footer{flex-wrap:wrap;gap:8px;}
  /* Upgrade banner */
  .upgrade-banner{flex-direction:column;gap:10px;}
}

/* ── Phone (≤480px) ── */
@media(max-width:480px){
  .container{padding:0 14px;}
  /* Auth */
  .auth-card{padding:24px 16px;border-radius:16px;}
  /* Stats 1 col for very small */
  .stats-grid{grid-template-columns:1fr 1fr;}
  /* Plans */
  .plans-grid{grid-template-columns:1fr;}
  /* Hero text */
  .hero-title{font-size:32px;}
  .hero-chips{gap:8px;}
  .hero-chip{font-size:12px;}
  /* Onboarding options */
  .option-grid{grid-template-columns:1fr 1fr;}
  /* Section titles */
  .section-title{font-size:24px;}
  /* Footer single col */
  .footer-inner{grid-template-columns:1fr;}
  /* Page title */
  .page-title{font-size:19px;}
  /* Mood row scrolls horizontally */
  .mood-row{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;}
  .mood-btn{flex-shrink:0;}
  /* Streak smaller */
  .streak-day{width:30px;height:30px;font-size:10px;}
  /* Card padding */
  .card{padding:16px 14px;}
  /* Sign out button - hide text on tiny screens */
  .dash-header .btn-ghost.btn-sm{padding:6px 10px;font-size:12px;}
  /* Reply form stacks on small */
  .reply-form{flex-direction:column;}
  .reply-form .btn-sm{width:100%;}
}

/* ── Desktop (≥1024px) ── */
@media(min-width:1024px){
  .dash-main{padding:28px 32px;}
  .wp-modal-overlay{align-items:center;padding:20px;}
  .wp-modal{border-radius:20px;max-width:500px;}
  .stats-grid{grid-template-columns:repeat(4,1fr);}
  .hero-section{min-height:90vh;}
  #wp-toast{left:auto;right:24px;text-align:left;}
}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px;}
