/* MaatraCare App — Thread 111 Cascading Design System
   Playfair Display + DM Sans | #2563EB + #10B981
   Dynamic alternating sections with scroll animations */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400&family=DM+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

:root {
  --font-d:'Playfair Display',Georgia,serif;
  --font-b:'DM Sans',-apple-system,sans-serif;
  --primary:#2563EB;--primary-dk:#1D4ED8;--primary-lt:#DBEAFE;--primary-glow:rgba(37,99,235,0.08);
  --accent:#10B981;--accent-dk:#059669;--accent-lt:#D1FAE5;
  --gold:#D4A574;--gold-rich:#B8860B;--gold-glow:rgba(212,165,116,0.12);
  --brown:#3D2B1F;--brown-md:#5C4033;--brown-lt:#8B7355;
  --error:#DC2626;--error-lt:#FEE2E2;--warning:#F59E0B;--warning-lt:#FEF3C7;
  --success:#10B981;--success-lt:#D1FAE5;
  --white:#FFFFFF;--cream:#FDF8F4;--cream-dk:#F5EDE4;
  --muted:#6B7280;--muted-lt:#9CA3AF;
  --border:#E5E0DB;--border-lt:#F0EBE6;
  --shadow-sm:0 1px 3px rgba(61,43,31,0.06);
  --shadow-md:0 4px 12px rgba(61,43,31,0.08);
  --shadow-lg:0 8px 30px rgba(61,43,31,0.12);
  --radius:10px;--radius-lg:16px;--radius-xl:24px;
  --transition:all 0.3s cubic-bezier(0.4,0,0.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);color:var(--brown);background:var(--cream);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:var(--font-b);border:none;background:none}
input,select,textarea{font-family:var(--font-b);font-size:1rem}

/* ═══ LOADING SPINNER ═══ */
.mc-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:mc-spin .7s linear infinite;margin:0 auto}
@keyframes mc-spin{to{transform:rotate(360deg)}}
.mc-loading{text-align:center;padding:2rem;color:var(--muted)}
.mc-loading p{margin-top:.75rem;font-size:.88rem}
.mc-toast{position:fixed;bottom:1.5rem;right:1.5rem;padding:.75rem 1.25rem;border-radius:var(--radius);font-size:.85rem;font-weight:500;z-index:9999;animation:mc-toast-in .3s ease;box-shadow:var(--shadow-lg)}
.mc-toast-ok{background:var(--accent-dk);color:#fff}
.mc-toast-err{background:var(--error);color:#fff}
.mc-toast-warn{background:var(--warning);color:#fff}
@keyframes mc-toast-in{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* Image Protection */
.pi{position:relative;display:inline-block;overflow:hidden;-webkit-user-select:none;user-select:none;width:100%}
.pi img{pointer-events:none;-webkit-user-drag:none;-webkit-touch-callout:none;width:100%;height:100%;object-fit:cover}
.pi::after{content:'';position:absolute;inset:0;z-index:2;background:transparent}

/* ═══ SCROLL ANIMATIONS (Cascading) ═══ */
.fade-in{opacity:0;transform:translateY(30px);transition:all 0.7s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}
.slide-left{opacity:0;transform:translateX(-60px);transition:all 0.7s ease}
.slide-left.visible{opacity:1;transform:translateX(0)}
.slide-right{opacity:0;transform:translateX(60px);transition:all 0.7s ease}
.slide-right.visible{opacity:1;transform:translateX(0)}
.scale-in{opacity:0;transform:scale(0.92);transition:all 0.6s ease}
.scale-in.visible{opacity:1;transform:scale(1)}

/* ═══ NAVBAR ═══ */
.navbar{background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;backdrop-filter:blur(12px)}
.nav-inner{max-width:1280px;margin:0 auto;padding:0 1.5rem;height:64px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:.6rem}
.nav-logo img{height:38px;width:38px;border-radius:8px;object-fit:cover}
.nav-logo-text{font-family:var(--font-d);font-size:1.3rem;font-weight:700;color:var(--brown)}
.nav-logo-text span{color:var(--primary)}
.nav-user{display:flex;align-items:center;gap:.75rem}
.nav-av{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dk));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem}
.nav-un{font-size:.85rem;font-weight:600;color:var(--brown-md)}
.nav-out{border:1px solid var(--border);border-radius:8px;padding:6px 14px;font-size:.8rem;font-weight:600;color:var(--brown-lt);transition:var(--transition)}
.nav-out:hover{border-color:var(--error);color:var(--error)}

/* ═══ SIDEBAR ═══ */
.sidebar{position:fixed;top:64px;left:0;width:260px;height:calc(100vh - 64px);background:var(--white);border-right:1px solid var(--border);overflow-y:auto;z-index:90;transition:transform .3s ease}
.sidebar-inner{padding:1.25rem .75rem}
.sb-section{margin-bottom:1.5rem}
.sb-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--muted-lt);padding:0 .75rem;margin-bottom:.5rem}
.sb-link{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:var(--radius);font-size:.88rem;font-weight:500;color:var(--brown-lt);transition:var(--transition);text-decoration:none}
.sb-link:hover{background:var(--primary-glow);color:var(--primary)}
.sb-link.active{background:var(--primary-lt);color:var(--primary);font-weight:600}
.sb-link .sb-icon{width:22px;text-align:center;font-size:1.1rem}

/* ═══ MAIN ═══ */
.main{margin-left:260px;min-height:calc(100vh - 64px)}
.page-inner{max-width:1020px;margin:0 auto;padding:0 1.5rem 3rem}

/* ═══ HERO BANNER (Split 280px) ═══ */
.hero-banner{position:relative;height:280px;overflow:hidden;display:flex;margin-bottom:2rem}
.hero-banner .hero-bg{position:absolute;inset:0;z-index:0}
.hero-text{flex:1;display:flex;flex-direction:column;justify-content:center;padding:2rem 2.5rem;z-index:2;position:relative}
.hero-text h1{font-family:var(--font-d);font-size:2rem;font-weight:700;color:#fff;margin-bottom:.5rem;line-height:1.2}
.hero-text p{font-size:1rem;color:rgba(255,255,255,0.85);max-width:400px;line-height:1.5}
.hero-img{flex:0 0 45%;position:relative;overflow:hidden;z-index:1}
.hero-img img{width:100%;height:100%;object-fit:cover}
.hero-img::before{content:'';position:absolute;inset:0;z-index:1}

/* Hero gradients */
.hg-blue{background:linear-gradient(135deg,#2563EB,#1D4ED8)}
.hg-blue .hero-img::before{background:linear-gradient(to right,#2563EB,transparent 40%)}
.hg-green{background:linear-gradient(135deg,#059669,#047857)}
.hg-green .hero-img::before{background:linear-gradient(to right,#059669,transparent 40%)}
.hg-gold{background:linear-gradient(135deg,#B8860B,#8B6914)}
.hg-gold .hero-img::before{background:linear-gradient(to right,#B8860B,transparent 40%)}
.hg-red{background:linear-gradient(135deg,#DC2626,#B91C1C)}
.hg-red .hero-img::before{background:linear-gradient(to right,#DC2626,transparent 40%)}
.hg-purple{background:linear-gradient(135deg,#7C3AED,#6D28D9)}
.hg-purple .hero-img::before{background:linear-gradient(to right,#7C3AED,transparent 40%)}
.hg-teal{background:linear-gradient(135deg,#0D9488,#0F766E)}
.hg-teal .hero-img::before{background:linear-gradient(to right,#0D9488,transparent 40%)}
.hg-amber{background:linear-gradient(135deg,#D97706,#B45309)}
.hg-amber .hero-img::before{background:linear-gradient(to right,#D97706,transparent 40%)}

/* ═══ CASCADING SECTIONS (alternating L/R) ═══ */
.cascade{display:flex;gap:2rem;align-items:center;padding:2rem;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-xl);margin-bottom:2rem;overflow:hidden}
.cascade.alt{flex-direction:row-reverse}
.cascade .cas-img{flex:0 0 280px;height:200px;border-radius:var(--radius-lg);overflow:hidden}
.cascade .cas-img img{width:100%;height:100%;object-fit:cover}
.cascade .cas-body{flex:1}
.cascade .cas-body h3{font-family:var(--font-d);font-size:1.35rem;color:var(--brown);margin-bottom:.5rem}
.cascade .cas-body p{font-size:.92rem;color:var(--muted);line-height:1.65;margin-bottom:.75rem}
.cascade .cas-body .cas-tag{display:inline-block;padding:.2rem .7rem;border-radius:20px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-right:.4rem}
.tag-blue{background:var(--primary-lt);color:var(--primary)}
.tag-green{background:var(--accent-lt);color:var(--accent-dk)}
.tag-gold{background:#FEF3C7;color:var(--gold-rich)}
.tag-red{background:var(--error-lt);color:var(--error)}
.tag-purple{background:#EDE9FE;color:#7C3AED}

/* ═══ SECTION HEADER ═══ */
.sec-head{font-family:var(--font-d);font-size:1.6rem;font-weight:600;color:var(--brown);margin-bottom:1.5rem;padding-bottom:.6rem;border-bottom:2px solid var(--border);display:flex;align-items:center;gap:.5rem}

/* ═══ CARDS ═══ */
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:var(--transition)}
.card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-lt)}
.card-grid{display:grid;gap:1.25rem;margin-bottom:2rem}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.card-title{font-family:var(--font-d);font-size:1.1rem;font-weight:600;color:var(--brown);margin-bottom:.25rem}
.card-desc{font-size:.88rem;color:var(--muted);line-height:1.5}

/* ═══ VITAL CARDS ═══ */
.vital-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;display:flex;gap:1rem;align-items:center;transition:var(--transition)}
.vital-card:hover{box-shadow:var(--shadow-md)}
.vital-card .v-img{flex:0 0 75px;height:75px;border-radius:var(--radius);overflow:hidden}
.vital-card .v-img img{width:100%;height:100%;object-fit:cover}
.vital-card .v-info{flex:1}
.vital-card .v-type{font-weight:600;color:var(--brown);font-size:.92rem}
.vital-card .v-val{font-family:var(--font-d);font-size:1.5rem;font-weight:700;color:var(--primary)}
.vital-card .v-unit{font-size:.78rem;color:var(--muted);font-weight:400}
.vital-card .v-time{font-size:.72rem;color:var(--muted-lt)}

/* ═══ STATS ═══ */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:2rem}
.stat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;text-align:center}
.stat-val{font-family:var(--font-d);font-size:2rem;font-weight:700;color:var(--primary);line-height:1}
.stat-lbl{font-size:.78rem;color:var(--muted);margin-top:.25rem;text-transform:uppercase;letter-spacing:.5px}

/* ═══ TABLE ═══ */
.dtable{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:1.5rem}
.dtable th{background:var(--cream-dk);font-size:.78rem;font-weight:700;color:var(--brown-lt);text-transform:uppercase;letter-spacing:.5px;padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}
.dtable td{padding:.75rem 1rem;font-size:.88rem;border-bottom:1px solid var(--border-lt)}
.dtable tr:last-child td{border-bottom:none}
.dtable tr:hover td{background:var(--primary-glow)}

/* ═══ BADGES ═══ */
.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .65rem;border-radius:20px;font-size:.72rem;font-weight:600}
.badge-ok{background:var(--success-lt);color:var(--accent-dk)}
.badge-warn{background:var(--warning-lt);color:#92400E}
.badge-err{background:var(--error-lt);color:var(--error)}
.badge-info{background:var(--primary-lt);color:var(--primary)}

/* ═══ BUTTONS ═══ */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.5rem;border-radius:var(--radius);font-weight:600;font-size:.88rem;transition:var(--transition);letter-spacing:.3px}
.btn-primary{background:var(--primary);color:#fff;border:2px solid var(--primary)}
.btn-primary:hover{background:var(--primary-dk);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary)}
.btn-outline:hover{background:var(--primary);color:#fff}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-rich));color:#fff;border:2px solid var(--gold)}
.btn-gold:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-danger{background:var(--error);color:#fff;border:2px solid var(--error)}
.btn-sm{padding:.4rem .9rem;font-size:.78rem}
.btn-lg{padding:.85rem 2rem;font-size:1rem}
.btn-block{width:100%;justify-content:center}

/* ═══ FORMS ═══ */
.form-group{margin-bottom:1.25rem}
.form-label{display:block;font-size:.85rem;font-weight:600;color:var(--brown-md);margin-bottom:.4rem}
.form-input{width:100%;padding:.7rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius);font-size:.95rem;transition:var(--transition);background:var(--white)}
.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%236B7280' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}

/* ═══ TOGGLE ═══ */
.toggle{position:relative;width:44px;height:24px;background:var(--border);border-radius:12px;cursor:pointer;transition:var(--transition)}
.toggle.on{background:var(--primary)}
.toggle::after{content:'';position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:var(--transition)}
.toggle.on::after{left:22px}

/* ═══ DASHBOARD SPECIFICS ═══ */
.dash-welcome h1{font-family:var(--font-d);font-size:1.8rem;color:var(--brown)}
.dash-welcome h1 em{font-style:normal;color:var(--primary)}
.dash-welcome p{color:var(--muted);font-size:.95rem}
.dash-hero{position:relative;border-radius:var(--radius-xl);overflow:hidden;height:220px;margin-bottom:2rem}
.dash-hero img{width:100%;height:100%;object-fit:cover}
.dash-hero .overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(37,99,235,0.85),rgba(16,185,129,0.7));display:flex;align-items:center;padding:2rem 2.5rem}
.dash-hero .overlay h2{font-family:var(--font-d);color:#fff;font-size:1.6rem;max-width:420px;line-height:1.3}
.dash-sos{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;background:rgba(220,38,38,0.05);border:1.5px solid rgba(220,38,38,0.2);border-radius:var(--radius-lg);margin-bottom:2rem;cursor:pointer;transition:var(--transition)}
.dash-sos:hover{background:rgba(220,38,38,0.1);border-color:rgba(220,38,38,0.4)}
.dash-sos .sos-t{font-weight:700;color:var(--error);text-transform:uppercase;letter-spacing:1px}

/* Faith Card */
.faith-card{background:linear-gradient(135deg,#FFF7ED,#FFFBEB);border:1px solid #FDE68A;border-radius:var(--radius-xl);padding:1.75rem;margin-bottom:2rem;overflow:hidden}
.faith-card .f-img{width:100%;max-height:160px;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:1rem}
.faith-card .f-img img{width:100%;height:100%;object-fit:cover}
.faith-card h3{font-family:var(--font-d);font-size:1.2rem;color:var(--brown);margin-bottom:.5rem}
.faith-card .shloka{font-family:var(--font-d);font-style:italic;font-size:1rem;color:var(--brown-md);line-height:1.6;margin-bottom:.4rem}
.faith-card .meaning{font-size:.85rem;color:var(--muted)}

/* Memory Card */
.memory-card{background:linear-gradient(135deg,#F0FDF4,#ECFDF5);border:1px solid #BBF7D0;border-radius:var(--radius-xl);padding:1.75rem;margin-bottom:2rem}
.memory-strip{display:flex;gap:.75rem;overflow-x:auto;padding:.5rem 0}
.mem-thumb{flex:0 0 85px;height:85px;border-radius:var(--radius);overflow:hidden;border:3px solid var(--white);box-shadow:var(--shadow-sm)}
.mem-thumb img{width:100%;height:100%;object-fit:cover}

/* Family Strip */
.fam-strip{display:flex;gap:1.25rem;overflow-x:auto;padding:.5rem 0;margin-bottom:2rem}
.fam-item{flex:0 0 auto;text-align:center}
.fam-av{width:56px;height:56px;border-radius:50%;background:var(--primary-lt);display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin:0 auto .3rem;border:3px solid var(--white);box-shadow:var(--shadow-sm)}
.fam-name{font-size:.72rem;color:var(--brown-lt);font-weight:500}

/* Plan badges */
.plan-badge{display:inline-flex;padding:.35rem .85rem;border-radius:20px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.plan-free{background:var(--cream-dk);color:var(--brown-lt)}
.plan-plus{background:var(--primary-lt);color:var(--primary)}
.plan-prem{background:linear-gradient(135deg,#FEF3C7,#FDE68A);color:var(--gold-rich)}

/* ═══ FOOTER ═══ */
.app-footer{background:var(--white);border-top:1px solid var(--border);padding:1.5rem;text-align:center;margin-top:3rem}
.app-footer p{font-size:.78rem;color:var(--muted-lt)}
.app-footer a{color:var(--primary);font-weight:500}

/* ═══ RESPONSIVE ═══ */
@media(max-width:1024px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0}
  .cols-3{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .nav-un{display:none}
  .hero-banner{height:auto;flex-direction:column}
  .hero-text{padding:1.5rem}
  .hero-text h1{font-size:1.5rem}
  .hero-img{height:180px;flex:none}
  .cascade{flex-direction:column!important}
  .cascade .cas-img{flex:none;width:100%;height:180px}
  .cols-2,.cols-3{grid-template-columns:1fr}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .page-inner{padding:0 1rem 2rem}
}
@media(max-width:480px){
  .stats-row{grid-template-columns:1fr}
  .hero-text h1{font-size:1.3rem}
}
