
:root{
    --purple-950:#381166;
    --purple-900:#321661;
    --purple-700:#7f47da;
    --purple-500:#8b5cf6;
    --purple-400:#a78bfa;
    --lime:#dcef4e;
    --lime-dark:#545f0e;
    --ink:#4a2a94;
    --paper:#ffffff;
    --white:#ffffff;
    --pink:#5c0794;
    --green:#52c03c;
    --blue:#312b86;
    --shadow-pop: 0 8px 0 rgba(65, 33, 133, 0.95);
    --font-display: 'Lilita One', system-ui, sans-serif;
    --font-hand: 'Arial Rounded MT Bold', system-ui, sans-serif;
    --font-body: 'Plus Jakarta Sans', system-ui, sans-serif;
  }
  *{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
  html{height:100%;}
  
  body{
    margin:0;
    font-family:var(--font-body);
    color:var(--ink);
    background:var(--paper);
    padding-bottom:0;
    min-height:100vh;
    display:flex;
    flex-direction:column;
  }
  main{flex:1 0 auto;}
  footer{flex-shrink:0;}
  button{font-family:inherit;cursor:pointer;border:none;background:none;}
  img,svg{display:block;}
  ::selection{background:var(--lime);color:var(--ink);}
  .wrap{max-width:1100px;margin:0 auto;padding:0 24px;}
  h1,h2,h3,h4{margin:0;}
  @media (prefers-reduced-motion: reduce){ *{animation-duration:.01ms !important; animation-iteration-count:1 !important;} }

  /* ---------- Topbar ---------- */
  .topbar{
    position:sticky;top:0;z-index:50;
    background:var(--ink);
    border-bottom:3px solid var(--purple-700);
  }
  .topbar-inner{
    width:100%;margin:0;padding:14px 32px;
    display:flex;align-items:center;justify-content:space-between;
    gap:12px;
  }
  .topbar-logo{
    font-family:var(--font-display);color:var(--white);font-size:1.2rem;
    padding:0;margin:0;line-height:1;text-decoration:none;display:inline-block;
    transition:opacity .15s ease;
  }
  .topbar-logo:hover, .topbar-logo:focus-visible{opacity:.85;}
  .topbar-logo b{color:var(--lime);font-style:normal;}
  .avatar-btn{
    width:38px;height:38px;border-radius:50%;background:var(--purple-500);
    color:var(--white);font-family:var(--font-display);font-size:1rem;
    display:flex;align-items:center;justify-content:center;border:2px solid var(--lime);
    flex:0 0 auto;
  }

  /* ---------- Hamburger + drawer nav ---------- */
  .hamburger-btn{
    width:38px;height:38px;border-radius:10px;background:var(--purple-700);
    border:2px solid var(--purple-500);display:flex;flex-direction:column;
    align-items:center;justify-content:center;gap:4px;flex:0 0 auto;
  }
  .hamburger-btn span{
    display:block;width:18px;height:2.5px;border-radius:2px;background:var(--lime);
    transition:transform .25s ease, opacity .2s ease;
  }
  .hamburger-btn.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
  .hamburger-btn.open span:nth-child(2){opacity:0;}
  .hamburger-btn.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

  .nav-overlay{
    position:fixed;inset:0;background:rgba(39, 30, 61, 0.55);z-index:90;
    opacity:0;pointer-events:none;transition:opacity .25s ease;
  }
  .nav-overlay.show{opacity:1;pointer-events:auto;}

  .nav-drawer{
    position:fixed;top:0;right:0;bottom:0;width:84%;max-width:300px;z-index:95;
    background:var(--ink);border-left:3px solid var(--purple-700);
    transform:translateX(100%);transition:transform .28s ease;
    display:flex;flex-direction:column;
  }
  .nav-drawer.show{transform:translateX(0);}
  .nav-drawer-head{
    display:flex;align-items:center;justify-content:space-between;
    padding:18px 18px 14px;border-bottom:2px solid var(--purple-900);
  }
  .nav-drawer-head .topbar-logo{font-size:1.05rem;}
  .nav-drawer-close{
    width:32px;height:32px;border-radius:8px;background:var(--purple-900);
    color:var(--lime);font-size:1.1rem;display:flex;align-items:center;justify-content:center;
    border:2px solid var(--purple-700);
  }
  .nav-drawer-user{
    display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:2px solid var(--purple-900);
  }
  .nav-drawer-user .av{
    width:42px;height:42px;border-radius:50%;background:var(--purple-500);color:var(--white);
    font-family:var(--font-display);font-size:1.05rem;display:flex;align-items:center;justify-content:center;
    border:2px solid var(--lime);flex:0 0 auto;
  }
  .nav-drawer-user .info p{margin:0;color:var(--white);font-size:.85rem;font-weight:700;}
  .nav-drawer-user .info span{font-size:.74rem;color:#bdb3d2;}
  .nav-drawer-list{list-style:none;margin:0;padding:10px;display:flex;flex-direction:column;gap:4px;flex:1;overflow-y:auto;}
  .nav-drawer-list li{margin:0;}
  .nav-drawer-link{
    width:100%;display:flex;align-items:center;gap:12px;padding:12px 12px;border-radius:12px;
    color:#cfc6e3;font-weight:700;font-size:.92rem;text-align:left;
  }
  .nav-drawer-link svg{width:19px;height:19px;flex:0 0 auto;}
  .nav-drawer-link:hover{background:var(--purple-900);}
  .nav-drawer-link.active{background:var(--purple-700);color:var(--white);}
  .nav-drawer-divider{height:2px;background:var(--purple-900);margin:8px 6px;border:none;}
  .nav-drawer-foot{padding:14px 18px 20px;}
  .nav-drawer-link.danger{color:var(--pink);}
  .nav-drawer-link.danger:hover{background:rgba(239,93,122,.12);}

  /* ---------- Screens ---------- */
  .screen{display:none;animation:fadeUp .3s ease;}
  .screen.active{display:block;}
  @keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

  /* ================= HERO ================= */
  .hero{
    position:relative;
    overflow:hidden;
    padding:72px 24px 100px;
    text-align:center;
    background:linear-gradient(120deg, var(--purple-950), var(--purple-700), var(--purple-900), var(--purple-950));
    background-size:320% 320%;
    animation:gradientShift 14s ease infinite;
  }
  @keyframes gradientShift{
    0%{background-position:0% 50%}
    50%{background-position:100% 50%}
    100%{background-position:0% 50%}
  }
  .hero-blob{
    position:absolute;border-radius:50%;
    filter:blur(8px);opacity:.35;pointer-events:none;
  }
  .hb1{width:260px;height:260px;background:var(--purple-500);top:-80px;left:-60px;animation:drift 9s ease-in-out infinite;}
  .hb2{width:200px;height:200px;background:var(--lime);bottom:-70px;right:-40px;opacity:.18;animation:drift 11s ease-in-out infinite reverse;}
  @keyframes drift{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(30px,20px) scale(1.12)}}

  .hero-doodles{position:absolute;inset:0;pointer-events:none;}
  .doodle{position:absolute;opacity:.8;}
  .d1{top:14%;left:6%;width:46px;animation:float 6s ease-in-out infinite;}
  .d2{top:20%;right:8%;width:38px;animation:float 7s ease-in-out infinite reverse;}
  .d3{bottom:14%;left:10%;width:34px;animation:spin 14s linear infinite;}
  .d4{bottom:22%;right:6%;width:40px;animation:float 5.5s ease-in-out infinite;}
  @keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
  @keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}

  .hero-inner{position:relative;z-index:2;max-width:680px;margin:0 auto;}
  .hero-bubble{
    display:inline-block;
    font-family:var(--font-hand);font-weight:700;font-size:1.2rem;color:var(--white);
    background:none;border:none;box-shadow:none;padding:0 .1em;
    position:relative;
    transform:rotate(-2deg);
    animation:wiggle 5s ease-in-out infinite, popIn .5s ease both;
  }
  .hero-bubble::after{
    content:"";position:absolute;left:-4%;right:-4%;bottom:-.14em;height:.2em;
    background:var(--lime);
    border-radius:40% 60% 55% 45% / 60% 35% 65% 40%;
    transform:rotate(1.5deg);
    z-index:-1;
  }
  @keyframes wiggle{0%,100%{transform:rotate(-2deg)}50%{transform:rotate(1.5deg)}}
  @keyframes popIn{from{opacity:0;transform:translateY(14px) rotate(-2deg)}to{opacity:1;transform:translateY(0) rotate(-2deg)}}

  .hero-title{
    font-family:var(--font-display);
    font-size:clamp(2.6rem,7vw,4.4rem);
    line-height:.98;color:var(--white);
    margin:20px 0 14px;
    animation:popIn .6s .1s ease both;
  }
  .hero-title .hi{
    color:var(--lime);background:transparent;
    padding:0 .05em;position:relative;
    display:inline-block;
  }
  .hero-title .hi::after{
    content:"";position:absolute;left:-3%;right:-3%;bottom:-.06em;height:.12em;
    background:var(--lime);
    border-radius:40% 60% 55% 45% / 60% 35% 65% 40%;
    transform:rotate(-1.5deg);
    z-index:-1;
  }
  .hero-sub{
    color:#e6def8;font-size:clamp(1rem,2vw,1.15rem);line-height:1.55;
    margin:0 auto 28px;max-width:520px;
    animation:popIn .6s .2s ease both;
  }
  .hero-ctas{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;animation:popIn .6s .3s ease both;}

  .btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    font-family:var(--font-display);font-size:1rem;padding:14px 26px;border-radius:999px;
    border:3px solid var(--ink);box-shadow:0 5px 0 var(--ink);transition:transform .12s ease;
  }
  .btn:active{transform:translateY(4px);box-shadow:0 1px 0 var(--ink);}
  .btn-lime{background:var(--lime);color:var(--ink);}
  .btn-purple{background:var(--purple-500);color:var(--white);}
  .btn-outline{background:transparent;color:var(--white);border-color:var(--white);box-shadow:0 5px 0 var(--white);}
  .btn-outline:active{box-shadow:0 1px 0 var(--white);}
  .btn-sm{padding:9px 16px;font-size:.85rem;box-shadow:0 4px 0 var(--ink);}
  .btn-sm:active{box-shadow:0 1px 0 var(--ink);}
  .btn-block{width:100%;}
  .btn[disabled]{opacity:.55;pointer-events:none;}

  /* ---------- Mission / benefits (Inicio) ---------- */
  .mission{max-width:720px;margin:0 auto;text-align:center;padding:56px 24px 8px;}
  .mission .eyebrow{font-family:var(--font-hand);font-weight:700;color:var(--purple-700);font-size:1.3rem;}
  .mission h2{font-family:var(--font-display);font-size:clamp(1.7rem,4vw,2.2rem);color:var(--purple-900);margin:6px 0 12px;}
  .mission p{color:#4a4256;font-size:.98rem;line-height:1.6;}

  .benefit-grid{
    display:grid;grid-template-columns:1fr;gap:36px;max-width:1080px;margin:0 auto;padding:32px 24px 24px;
  }
  @media(min-width:640px){.benefit-grid{grid-template-columns:repeat(2,1fr);}}
  @media(min-width:980px){.benefit-grid{grid-template-columns:repeat(4,1fr);gap:8px;}}

  .benefit-card{
    background:none;border:none;border-radius:16px;padding:10px 18px 6px;
    text-align:center;cursor:pointer;position:relative;width:100%;
    transition:transform .18s ease;
    -webkit-tap-highlight-color:transparent;
  }
  @media(min-width:980px){
    .benefit-card::before{
      content:"";position:absolute;left:0;top:14px;bottom:14px;width:0;
      border-left:2px dashed var(--purple-400);opacity:.4;
    }
    .benefit-card:first-child::before{display:none;}
  }
  .benefit-card:hover{transform:translateY(-6px);}
  .benefit-card:hover .benefit-icon{transform:scale(1.08) rotate(-5deg);}
  .benefit-card:active{transform:translateY(-2px) scale(.97);}
  .benefit-card:focus-visible{outline:3px solid var(--purple-500);outline-offset:4px;border-radius:20px;}

  .benefit-icon{
    width:78px;height:78px;border-radius:50%;
    background:linear-gradient(150deg,var(--purple-400),var(--purple-500));
    display:flex;align-items:center;justify-content:center;margin:0 auto 18px;
    box-shadow:0 6px 0 rgba(74,42,148,.22);
    transition:transform .2s ease;
  }
  .benefit-icon svg, .benefit-icon img{width:34px;height:34px;}

  .benefit-card h3{
    font-family:var(--font-display);font-size:1.02rem;letter-spacing:.02em;
    text-transform:uppercase;color:var(--purple-950);
    margin:0 0 10px;position:relative;display:inline-block;
  }
  .benefit-card h3::before{
    content:"";position:absolute;left:-9%;right:-9%;bottom:.02em;height:.4em;
    background:var(--purple-500);opacity:.85;z-index:-1;
    border-radius:40% 60% 55% 45% / 60% 35% 65% 40%;
    transform:rotate(-2deg);
  }
  .benefit-card:nth-child(2n) h3::before{transform:rotate(2deg);}
  .benefit-card:nth-child(3n) h3::before{transform:rotate(-1deg) scaleX(1.03);}

  .benefit-card p{margin:0;font-size:.85rem;color:#4a4256;line-height:1.5;max-width:220px;margin-inline:auto;}

  .start-cta{text-align:center;padding:36px 24px 64px;}
  .start-cta p{color:#4a4256;font-size:.92rem;margin-bottom:16px;}

  /* ---------- Generic screen head ---------- */
  .screen-head{max-width:700px;margin:0 auto;padding:40px 24px 6px;}
  .screen-head .eyebrow{font-family:var(--font-hand);font-weight:700;font-size:1.25rem;}
  .screen-head h2{font-family:var(--font-display);font-size:clamp(1.6rem,3.6vw,2.2rem);margin:6px 0 8px;}
  .screen-head p{font-size:.92rem;color:#4a4256;line-height:1.5;margin:0;}

  /* ================= CASOS ================= */
  .casos-eyebrow{color:var(--purple-700);}
  .casos-h{color:var(--purple-900);}

  .chip-row{
    display:flex;flex-wrap:wrap;gap:10px;justify-content:center;
    max-width:760px;margin:0 auto;padding:18px 24px 8px;
  }
  .chip{
    background:var(--white);border:2.5px solid var(--ink);border-radius:999px;
    padding:10px 18px;font-weight:700;font-size:.88rem;color:var(--ink);
    box-shadow:0 4px 0 var(--ink);transition:transform .12s ease, background .15s ease;
  }
  .chip:hover{transform:translateY(-2px);}
  .chip.active{background:var(--purple-500);color:var(--white);}
  .chip:active{transform:translateY(3px);box-shadow:0 1px 0 var(--ink);}

  .case-detail{
    max-width:760px;margin:24px auto 0;background:var(--white);border:3px solid var(--ink);
    border-radius:20px;box-shadow:var(--shadow-pop);padding:26px 24px;display:none;
  }
  .case-detail.show{display:block;animation:popIn2 .25s ease;}
  @keyframes popIn2{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
  .case-detail h3{font-family:var(--font-display);font-size:1.2rem;color:var(--purple-900);margin-bottom:4px;}
  .case-tag{display:inline-block;background:var(--lime);border:2px solid var(--ink);border-radius:999px;
    padding:3px 12px;font-size:.72rem;font-weight:800;margin-bottom:12px;}
  .case-detail .lbl{font-weight:800;font-size:.78rem;text-transform:uppercase;letter-spacing:.4px;color:var(--purple-700);margin:14px 0 4px;}
  .case-detail p{font-size:.92rem;line-height:1.55;color:#2a2333;margin:0;}
  .rights-list{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-direction:column;gap:8px;}
  .rights-list li{display:flex;gap:9px;align-items:flex-start;font-size:.9rem;color:#2a2333;}
  .rights-list li::before{content:'✓';color:var(--green);font-weight:800;flex:0 0 auto;}
  .case-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px;}

  .faq-wrap{max-width:760px;margin:36px auto 0;padding:0 24px;}
  .faq-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
  .faq-head h4{font-family:var(--font-display);font-size:1rem;color:var(--purple-900);}
  .faq-item{
    background:var(--white);border:2px solid var(--ink);border-radius:14px;margin-bottom:10px;overflow:hidden;
  }
  .faq-q{
    width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;
    padding:14px 16px;font-weight:700;font-size:.88rem;text-align:left;color:var(--ink);
  }
  .faq-q .star{font-size:1rem;flex:0 0 auto;}
  .faq-q .star.fav{filter:none;}
  .faq-chevron{transition:transform .2s ease;flex:0 0 auto;}
  .faq-item.open .faq-chevron{transform:rotate(180deg);}
  .faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease;}
  .faq-item.open .faq-a{max-height:200px;}
  .faq-a p{margin:0;padding:0 16px 16px;font-size:.86rem;color:#4a4256;line-height:1.5;}
  .faq-more{text-align:center;margin-top:6px;}

  /* ================= EVIDENCIAS ================= */
  .ev-eyebrow{color:var(--purple-700);}
  .section-block{max-width:900px;margin:0 auto;padding:30px 24px 0;}
  .section-block h4{font-family:var(--font-display);font-size:1rem;color:var(--purple-900);margin-bottom:14px;}

  .ev-type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
  @media(min-width:640px){.ev-type-grid{grid-template-columns:repeat(3,1fr);}}
  .ev-type-btn{
    background:var(--white);border:2.5px solid var(--ink);border-radius:14px;
    padding:16px 10px;text-align:center;font-weight:700;font-size:.82rem;
    box-shadow:0 4px 0 var(--ink);transition:transform .12s ease;
  }
  .ev-type-btn:hover{transform:translateY(-3px);}
  .ev-type-btn .ic{font-size:1.4rem;margin-bottom:6px;}

  .ev-form{
    display:none;max-width:480px;margin:18px auto 0;background:#fff7e0;border:3px solid var(--ink);
    border-radius:16px;padding:20px;box-shadow:var(--shadow-pop);
  }
  .ev-form.show{display:block;animation:popIn2 .2s ease;}
  .ev-form label{display:block;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.3px;color:var(--purple-700);margin-bottom:5px;}
  .ev-form input, .ev-form textarea{
    width:100%;border:2px solid var(--ink);border-radius:10px;padding:10px 12px;font-family:inherit;
    font-size:.88rem;margin-bottom:14px;background:var(--white);
  }
  .ev-form textarea{resize:vertical;min-height:60px;}
  .ev-form-actions{display:flex;gap:10px;}

  .ev-list{display:flex;flex-direction:column;gap:10px;margin-top:14px;}
  .ev-item{
    display:flex;align-items:center;gap:12px;background:var(--white);border:2px solid var(--ink);
    border-radius:14px;padding:12px 14px;
  }
  .ev-item .ic{font-size:1.3rem;flex:0 0 auto;}
  .ev-item .meta{flex:1;min-width:0;}
  .ev-item .meta .t{font-weight:700;font-size:.88rem;}
  .ev-item .meta .d{font-size:.75rem;color:#6b6178;}
  .ev-item .acts{display:flex;gap:6px;flex:0 0 auto;}
  .icon-btn{
    width:30px;height:30px;border-radius:8px;background:var(--paper);border:2px solid var(--ink);
    display:flex;align-items:center;justify-content:center;font-size:.85rem;
  }
  .ev-empty{font-size:.86rem;color:#6b6178;text-align:center;padding:18px;border:2px dashed #cdc4dd;border-radius:14px;margin-top:14px;}

  /* ================= APRENDER (Quiz) ================= */
  .ap-eyebrow
  {color:var(--purple-700)}
  .quiz-card{
    max-width:560px;
    margin:20px auto 60px;
    background:var(--white);
    border:3px solid var(--ink);
    border-radius:22px;
    box-shadow:var(--shadow-pop);
    padding:30px 26px 26px;
    position:relative;}

  .quiz-progress
  {display:flex;
    justify-content:center;
    gap:7px;
    margin-bottom:18px;}

  .dot
  {width:9px;
    height:9px;
    border-radius:50%;
    background:#bca9e9;
    border:2px solid var(--ink);}

  .dot.active
  {background:var(--purple-500);}

  .dot.done
  {background:var(--lime);}

  .quiz-score{
    position:absolute;top:-16px;right:-10px;background:var(--lime);border:3px solid var(--ink);
    border-radius:999px;padding:7px 15px;font-family:var(--font-display);font-size:.85rem;
    transform:rotate(6deg);box-shadow:var(--shadow-pop);
  }
  .quiz-tag{display:block;font-family:var(--font-hand);font-weight:700;font-size:1.1rem;color:var(--purple-700);margin-bottom:8px;}
  .quiz-situation{font-size:1.18rem;font-weight:700;line-height:1.34;color:var(--ink);min-height:72px;}
  .quiz-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px;}
  .quiz-actions .btn{width:100%;justify-content:flex-start;font-size:.92rem;text-align:left;padding:13px 18px;}
  .quiz-feedback{margin-top:18px;border-radius:16px;padding:18px;border:3px solid var(--ink);display:none;animation:popIn2 .22s ease;}
  .quiz-feedback.show{display:block;}
  .quiz-feedback.ok{background:#e8f6df;}
  .quiz-feedback.bad{background:#fde8e0;}
  .feedback-verdict{font-family:var(--font-display);font-size:1.02rem;margin-bottom:6px;}
  .feedback-verdict.legal{color:#2f7a3a;}
  .feedback-verdict.ilegal{color:#b8401c;}
  .feedback-text{font-size:.9rem;line-height:1.5;color:#2a2333;margin:0;}
  .quiz-next{display:none;margin-top:16px;width:100%;}
  .quiz-next.show{display:inline-flex;}
  .quiz-done{display:none;text-align:center;}
  .quiz-done.show{display:block;}
  .quiz-done h3{font-family:var(--font-display);color:var(--purple-700);font-size:1.3rem;margin-bottom:8px;}
  .quiz-done p{color:#3a3045;font-size:.9rem;margin-bottom:16px;}
  .shake{animation:shake .35s ease;}
  @keyframes shake{10%,90%{transform:translateX(-1px)}20%,80%{transform:translateX(2px)}30%,50%,70%{transform:translateX(-4px)}40%,60%{transform:translateX(4px)}}

  /* ================= GUARDADOS ================= */
  .gd-eyebrow{color:var(--green);}
  .tabs{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;max-width:700px;margin:18px auto 0;padding:0 24px;}
  .tab-btn{
    background:var(--white);border:2.5px solid var(--ink);border-radius:999px;padding:9px 16px;
    font-weight:700;font-size:.84rem;box-shadow:0 4px 0 var(--ink);
  }
  .tab-btn.active{background:var(--green);color:var(--white);}
  .tab-panel{display:none;max-width:760px;margin:20px auto 60px;padding:0 24px;}
  .tab-panel.active{display:block;}
  .gd-item{
    display:flex;align-items:center;gap:12px;background:var(--white);border:2px solid var(--ink);
    border-radius:14px;padding:14px 16px;margin-bottom:10px;
  }
  .gd-item .ic{font-size:1.3rem;}
  .gd-item .meta .t{font-weight:700;font-size:.9rem;}
  .gd-item .meta .d{font-size:.76rem;color:#6b6178;}

  /* ================= PERFIL ================= */
  .pf-eyebrow{color:var(--blue);}
  .profile-card{
    max-width:560px;margin:20px auto 0;background:var(--white);border:3px solid var(--ink);
    border-radius:20px;box-shadow:var(--shadow-pop);padding:26px;display:flex;gap:18px;align-items:center;
  }
  .profile-avatar{
    width:64px;height:64px;border-radius:50%;background:var(--blue);color:var(--white);
    font-family:var(--font-display);font-size:1.6rem;display:flex;align-items:center;justify-content:center;
    flex:0 0 auto;border:3px solid var(--ink);
  }
  .profile-card h3{font-family:var(--font-display);font-size:1.15rem;color:var(--purple-900);}
  .profile-card p{margin:4px 0 0;font-size:.85rem;color:#6b6178;}

  .stat-row{display:flex;gap:14px;max-width:560px;margin:20px auto;flex-wrap:wrap;justify-content:center;}
  .stat-card{
    flex:1;min-width:130px;background:var(--ink);border:2.5px solid var(--purple-700);border-radius:14px;
    padding:16px;text-align:center;
  }
  .stat-card .n{font-family:var(--font-display);font-size:1.6rem;color:var(--lime);}
  .stat-card .l{font-size:.74rem;color:#bdb3d2;margin-top:2px;}

  .menu-list{max-width:560px;margin:0 auto 60px;display:flex;flex-direction:column;gap:8px;}
  .menu-row{
    display:flex;align-items:center;justify-content:space-between;background:var(--white);
    border:2px solid var(--ink);border-radius:12px;padding:13px 16px;font-weight:700;font-size:.88rem;
  }
  .menu-row .left{display:flex;align-items:center;gap:10px;}
  .menu-row.danger{color:var(--pink);}

  /* ================= LOGIN ================= */
  .lg-eyebrow{color:var(--purple-700);}
  .login-card{
    max-width:420px;margin:24px auto 60px;background:var(--white);border:3px solid var(--ink);
    border-radius:22px;box-shadow:var(--shadow-pop);padding:30px 26px;
  }
  .login-card .lg-icon{
    width:52px;height:52px;border-radius:14px;background:var(--lime);border:2.5px solid var(--ink);
    display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:16px;
  }
  .login-card h3{font-family:var(--font-display);font-size:1.3rem;color:var(--purple-900);margin-bottom:4px;}
  .login-card .sub{font-size:.85rem;color:#6b6178;margin:0 0 20px;}
  .login-card label{display:block;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.3px;color:var(--purple-700);margin-bottom:5px;}
  .login-card input{
    width:100%;border:2px solid var(--ink);border-radius:10px;padding:11px 13px;font-family:inherit;
    font-size:.92rem;margin-bottom:16px;background:var(--paper);
  }
  .login-card input:focus{outline:3px solid var(--purple-400);outline-offset:1px;}
  .login-error{
    display:none;background:#fde8e0;border:2px solid var(--ink);border-radius:10px;
    padding:10px 12px;font-size:.82rem;color:#b8401c;font-weight:700;margin-bottom:14px;
  }
  .login-error.show{display:block;}
  .login-switch{text-align:center;font-size:.84rem;color:#4a4256;margin-top:18px;}
  .login-switch button{color:var(--purple-700);font-weight:800;text-decoration:underline;}
  .login-success{display:none;text-align:center;}
  .login-success.show{display:block;}
  .login-success .lg-icon{margin:0 auto 16px;background:var(--green);}
  .login-success h3{margin-bottom:8px;}
  .login-success p{font-size:.88rem;color:#4a4256;margin-bottom:18px;}

  footer{background:var(--purple-950);padding:30px 24px;text-align:center;}
  footer p{color:#8f80ad;font-size:.78rem;margin:4px 0;}