:root{--sand:#F7EDDA;--sand2:#EDD9B0;--earth:#7A4F2D;--earth2:#B87333;--orange:#E8843A;--yellow:#F5C842;--green:#3D7A52;--green2:#5CAF77;--sky:#6BAED4;--red:#C0392B;--text:#2E1A0E;--white:#FFFCF3;--shadow:rgba(90,50,20,0.18)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Baloo 2',cursive;background:var(--sand);min-height:100vh;color:var(--text);overflow-x:hidden}
/* JUNGLE */
.jungle-bg{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.leaf{position:absolute;opacity:.08;animation:leafSway 6s ease-in-out infinite;user-select:none}
@keyframes leafSway{0%,100%{transform:rotate(-8deg)}50%{transform:rotate(8deg) scale(1.05)}}
/* SCREENS */
.screen{display:none;position:relative;z-index:1}
.screen.active{display:block}
#screen-login.active{display:flex;min-height:100vh;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px}
/* LOGIN */
.login-card{background:var(--white);border-radius:32px;padding:36px 30px 28px;max-width:420px;width:100%;box-shadow:0 16px 48px var(--shadow);border:3px solid var(--earth2);position:relative;overflow:hidden}
.login-card::before{content:'';position:absolute;top:0;left:0;right:0;height:6px;background:repeating-linear-gradient(90deg,var(--yellow) 0,var(--yellow) 20px,var(--orange) 20px,var(--orange) 40px,var(--earth2) 40px,var(--earth2) 60px)}
.login-mascot{text-align:center;font-size:5rem;margin-bottom:4px;animation:mascotBounce 2.5s ease-in-out infinite;line-height:1}
@keyframes mascotBounce{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-10px) rotate(3deg)}}
.login-title{font-family:'Fredoka One',cursive;font-size:2.2rem;text-align:center;color:var(--earth);line-height:1.1;margin-bottom:2px}
.login-title span{color:var(--orange)}
.login-sub{text-align:center;font-size:.85rem;color:var(--earth2);font-weight:600;margin-bottom:22px}
.form-tabs{display:flex;border-radius:14px;overflow:hidden;border:2.5px solid var(--sand2);margin-bottom:18px}
.form-tab{flex:1;padding:9px;text-align:center;font-family:'Fredoka One',cursive;font-size:1rem;color:var(--earth2);background:var(--sand);cursor:pointer;border:none;outline:none;transition:all .2s}
.form-tab.active{background:var(--earth);color:var(--white)}
.field-group{margin-bottom:12px}
.field-label{font-size:.8rem;font-weight:700;color:var(--earth);margin-bottom:4px;display:block}
.field-input{width:100%;background:var(--sand);border:2.5px solid var(--sand2);border-radius:12px;padding:10px 14px;font-family:'Baloo 2',cursive;font-size:.95rem;color:var(--text);outline:none;transition:border .2s}
.field-input:focus{border-color:var(--orange);background:var(--white)}
.btn-primary{width:100%;background:linear-gradient(135deg,var(--orange),var(--earth2));border:none;border-radius:14px;padding:13px;font-family:'Fredoka One',cursive;font-size:1.1rem;color:var(--white);cursor:pointer;box-shadow:0 6px 18px rgba(232,132,58,.35);transition:transform .15s;position:relative}
.btn-primary:hover{transform:translateY(-2px)}
.btn-primary:active{transform:scale(.97)}
.btn-primary:disabled{opacity:.6;transform:none;cursor:not-allowed}
.error-msg{background:rgba(192,57,43,.1);color:var(--red);border-radius:10px;padding:8px 14px;font-size:.82rem;font-weight:700;margin-bottom:12px;display:none;border-left:4px solid var(--red)}
.error-msg.visible{display:block}
.animals-row{text-align:center;font-size:1.5rem;letter-spacing:8px;margin-top:18px;opacity:.5;animation:march 4s ease-in-out infinite}
@keyframes march{0%,100%{letter-spacing:8px}50%{letter-spacing:14px}}
/* HEADER */
.app-header{background:linear-gradient(160deg,#2D6A4A 0%,#3D7A52 60%,#4a9664 100%);padding:14px 16px 18px;position:relative;overflow:hidden;box-shadow:0 4px 20px rgba(45,106,74,.35)}
.app-header::before{content:'🌿';position:absolute;top:-6px;right:10px;font-size:3.5rem;opacity:.18;transform:rotate(20deg)}
.app-header::after{content:'🍃';position:absolute;bottom:-4px;left:6px;font-size:2.5rem;opacity:.15;transform:rotate(-15deg)}
.app-header::before,.app-header::after{pointer-events:none}
.header-top{display:flex;align-items:center;justify-content:space-between;max-width:700px;margin:0 auto 10px;position:relative;z-index:1}
.header-logo-wrap{display:flex;align-items:center;gap:8px}
.header-logo-icon{font-size:2rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}
.header-logo-text{font-family:'Fredoka One',cursive;font-size:1.55rem;color:#fff;line-height:1;text-shadow:0 2px 8px rgba(0,0,0,.15)}
.header-logo-text span{color:var(--yellow)}
.header-user-badge{display:flex;align-items:center;gap:6px}
.avatar-circle{width:30px;height:30px;background:var(--yellow);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;color:var(--earth)}
.header-username{color:rgba(255,255,255,.85);font-weight:700;font-size:.78rem}
.btn-logout{background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.25);border-radius:99px;padding:4px 10px;color:rgba(255,255,255,.9);font-family:'Baloo 2',cursive;font-size:.75rem;font-weight:700;cursor:pointer;transition:background .2s}
.btn-logout:hover{background:rgba(255,255,255,.25)}
.header-tagline{text-align:center;color:rgba(255,255,255,.82);font-size:.82rem;font-weight:600;max-width:700px;margin:0 auto;position:relative;z-index:1}
/* CIRCULAR PROGRESS */
.inicio-hero{max-width:700px;margin:0 auto;padding:18px 16px 10px;display:flex;align-items:center;gap:20px}
.circ-wrap{position:relative;width:100px;height:100px;flex-shrink:0}
.circ-svg{width:100%;height:100%;transform:rotate(-90deg)}
.circ-bg{fill:none;stroke:var(--sand2);stroke-width:10}
.circ-fill{fill:none;stroke:url(#circGrad);stroke-width:10;stroke-linecap:round;stroke-dasharray:283;stroke-dashoffset:283;transition:stroke-dashoffset .8s cubic-bezier(.4,0,.2,1)}
.circ-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.circ-pct{font-family:'Fredoka One',cursive;font-size:1.4rem;color:var(--green);line-height:1}
.circ-sub{font-size:.6rem;font-weight:800;color:var(--earth2);text-transform:uppercase;letter-spacing:.03em}
.inicio-info{flex:1;min-width:0}
.inicio-title{font-family:'Fredoka One',cursive;font-size:1.1rem;color:var(--earth);margin-bottom:4px}
.progress-track{background:var(--sand2);border-radius:99px;height:14px;overflow:visible;box-shadow:inset 0 2px 4px rgba(0,0,0,.08);position:relative;margin-bottom:6px}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--green2),#7bc47f);background-size:200% 100%;border-radius:99px;transition:width .7s cubic-bezier(.4,0,.2,1);animation:shimmer 3s linear infinite}
@keyframes shimmer{0%{background-position:0% 0}100%{background-position:200% 0}}
.progress-giraffe{position:absolute;top:-10px;font-size:1.6rem;transition:left .7s cubic-bezier(.4,0,.2,1);pointer-events:none;line-height:1}
.inicio-msg{font-size:.75rem;font-weight:700;color:var(--earth2);line-height:1.35}
/* BOTTOM NAV */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid rgba(0,0,0,.07);display:flex;z-index:100;box-shadow:0 -4px 16px rgba(0,0,0,.08);padding-bottom:env(safe-area-inset-bottom)}
.bnav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px 10px;border:none;background:none;cursor:pointer;gap:3px;transition:transform .15s}
.bnav-btn:active{transform:scale(.92)}
.bnav-icon{font-size:1.35rem;line-height:1;transition:transform .2s}
.bnav-label{font-family:'Baloo 2',cursive;font-size:.62rem;font-weight:800;color:#aaa;transition:color .2s;letter-spacing:.01em}
.bnav-btn.active .bnav-label{color:var(--green)}
.bnav-btn.active .bnav-icon{transform:scale(1.15)}
/* SECTIONS */
.bnav-section{display:none}
.bnav-section.active{display:block}
/* MURAL */
.mural-wrap{max-width:560px;margin:0 auto;padding:14px 14px 100px}
.mural-header{text-align:center;padding:14px 0 18px}
.mural-header-title{font-family:'Fredoka One',cursive;font-size:1.3rem;color:var(--earth);margin-bottom:4px}
.mural-header-sub{font-size:.78rem;color:var(--earth2);font-weight:700}
.mural-section-title{font-family:'Fredoka One',cursive;font-size:1rem;color:var(--earth);margin:0 0 10px;display:flex;align-items:center;gap:8px}
.mural-count{background:var(--earth);color:#fff;font-size:.7rem;font-family:'Baloo 2',cursive;font-weight:800;border-radius:99px;padding:2px 8px}
.mural-empty{text-align:center;color:#bbb;font-size:.82rem;font-weight:700;padding:18px 12px;background:#fff;border-radius:14px;margin-bottom:10px}
.mural-card{display:flex;align-items:flex-start;gap:12px;background:#fff;border-radius:16px;padding:13px 14px;margin-bottom:10px;box-shadow:0 2px 10px rgba(0,0,0,.07)}
.mural-card.mural-pledge{border-left:4px solid var(--green)}
.mural-card.mural-received{border-left:4px solid #f0a940;opacity:.85}
.mural-avatar{width:38px;height:38px;border-radius:50%;background:var(--green);color:#fff;font-family:'Fredoka One',cursive;font-size:.95rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mural-avatar.done{background:#f0a940}
.mural-body{flex:1;min-width:0}
.mural-who{font-size:.8rem;color:var(--earth2);font-weight:700;margin-bottom:2px}
.mural-item{font-size:.92rem;font-weight:800;color:var(--earth);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mural-meta{font-size:.72rem;color:#aaa;margin-top:3px;font-weight:700}
.mural-time{font-size:.7rem;color:#ccc;margin-top:2px}
.mural-badge{font-size:1.3rem;flex-shrink:0;align-self:center}
.mural-divider{height:1px;background:rgba(0,0,0,.07);margin:18px 0}
.mural-more-btn{display:block;width:100%;padding:10px;background:none;border:2px dashed rgba(0,0,0,.1);border-radius:12px;font-family:'Baloo 2',cursive;font-weight:800;font-size:.82rem;color:var(--earth2);cursor:pointer;margin-bottom:10px;transition:background .15s}
.mural-more-btn:hover{background:rgba(0,0,0,.04)}
/* GIFT CARDS (evento) */
.gift-list{display:flex;flex-direction:column;gap:10px;margin:10px 0 4px}
.gift-card{background:rgba(255,255,255,.7);border-radius:14px;padding:12px 14px;border:1.5px solid rgba(0,0,0,.08)}
.gift-card-complete{opacity:.7;border-color:rgba(0,0,0,.05)}
.gift-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.gift-card-name{font-weight:800;font-size:.9rem;color:var(--earth);flex:1}
.gift-tag-complete{font-size:.85rem;font-weight:700;color:#aaa}
.gift-progress-bar{height:7px;background:rgba(0,0,0,.08);border-radius:99px;overflow:hidden;margin-bottom:5px}
.gift-progress-fill{height:100%;background:var(--green);border-radius:99px;transition:width .4s}
.gift-qty-text{font-size:.75rem;font-weight:700;color:var(--earth2);margin-bottom:4px}
.gift-pledgers{font-size:.75rem;color:#aaa;margin-top:3px}
.gift-my-pledge{font-size:.78rem;color:var(--green);font-weight:800;margin-top:4px}
.gift-notes{font-size:.75rem;color:#bbb;margin-top:3px}
/* QTY SELECTOR */
.qty-selector{display:flex;align-items:center;justify-content:center;gap:18px;margin:12px 0 4px}
.qty-btn{width:40px;height:40px;border-radius:50%;border:2px solid var(--earth);background:none;font-size:1.4rem;font-weight:800;color:var(--earth);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
.qty-btn:hover{background:var(--earth);color:#fff}
.qty-display{font-family:'Fredoka One',cursive;font-size:2rem;color:var(--earth);min-width:48px;text-align:center}
/* TABS */
.tabs-wrap{max-width:700px;margin:14px auto 0;padding:0 12px;display:flex;gap:7px;overflow-x:auto;scrollbar-width:none}
.tabs-wrap::-webkit-scrollbar{display:none}
.tab-btn{flex-shrink:0;background:var(--white);border:2px solid var(--sand2);border-radius:20px;padding:6px 12px;font-family:'Fredoka One',cursive;font-size:.85rem;color:var(--earth2);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:5px;white-space:nowrap;box-shadow:0 2px 6px var(--shadow)}
.tab-btn .tbadge{background:var(--sand2);color:var(--earth);border-radius:99px;font-size:.68rem;padding:1px 6px;font-family:'Baloo 2',cursive;font-weight:800}
.tab-btn.active{background:var(--green);border-color:var(--green);color:var(--white)}
.tab-btn.active .tbadge{background:var(--yellow);color:var(--earth)}
.tab-btn:hover:not(.active){border-color:var(--green2);transform:translateY(-1px)}
/* CONTENT */
.app-content{max-width:700px;margin:14px auto 0;padding:0 12px 100px}
.section{display:none;animation:fadeUp .3s ease}
.section.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.add-btn-wrap{margin-bottom:12px;display:flex;justify-content:flex-end}
.btn-add-item{background:var(--green);border:none;border-radius:99px;padding:7px 16px;color:var(--white);font-family:'Fredoka One',cursive;font-size:.88rem;cursor:pointer;display:flex;align-items:center;gap:5px;box-shadow:0 4px 12px rgba(61,122,82,.3);transition:transform .15s}
.btn-add-item:hover{transform:translateY(-2px)}
/* CAT CARD */
.cat-card{background:var(--white);border-radius:20px;margin-bottom:14px;overflow:hidden;box-shadow:0 4px 16px var(--shadow);border:2px solid rgba(184,115,51,.12)}
.cat-header{padding:11px 15px;display:flex;align-items:center;justify-content:space-between;border-bottom:2px dashed rgba(184,115,51,.18);background:linear-gradient(90deg,rgba(245,200,66,.1),transparent)}
.cat-title-text{font-family:'Fredoka One',cursive;font-size:1rem;color:var(--earth)}
.cat-pct{font-size:.75rem;font-weight:800;color:var(--green);background:rgba(61,122,82,.1);border-radius:99px;padding:2px 9px}
.cat-body{padding:4px 8px 10px}
/* ITEM */
.item{display:flex;align-items:flex-start;gap:9px;padding:8px 6px;border-radius:11px;cursor:pointer;transition:background .15s;animation:itemIn .25s ease;position:relative}
@keyframes itemIn{from{opacity:0;transform:translateX(-6px)}to{opacity:1;transform:translateX(0)}}
.item+.item{border-top:1px dashed rgba(184,115,51,.15)}
.item:hover{background:rgba(232,132,58,.06)}
.check-box{width:27px;height:27px;min-width:27px;border-radius:9px;border:2.5px solid var(--sand2);background:var(--sand);display:flex;align-items:center;justify-content:center;transition:all .22s;margin-top:1px}
.item.checked .check-box{background:var(--green);border-color:var(--green);animation:checkPop .3s ease}
@keyframes checkPop{0%{transform:scale(1)}50%{transform:scale(1.25) rotate(-5deg)}100%{transform:scale(1)}}
.check-icon{opacity:0;color:white;font-weight:900;font-size:.95rem;transition:all .2s;transform:scale(.4)}
.item.checked .check-icon{opacity:1;transform:scale(1)}
.item-info{flex:1;min-width:0}
.item-label{font-size:.9rem;font-weight:700;color:var(--text);line-height:1.35;transition:all .2s}
.item.checked .item-label{text-decoration:line-through;color:#aaa}
.item-who{font-size:.7rem;color:var(--earth2);font-weight:600;margin-top:2px;flex-wrap:wrap;display:flex;align-items:center;gap:3px}
.who-name{background:rgba(184,115,51,.12);border-radius:99px;padding:1px 6px;color:var(--earth);font-weight:700}
.pledge-note{margin-top:5px;display:inline-flex;align-items:center;gap:5px;background:linear-gradient(135deg,rgba(245,200,66,.3),rgba(232,132,58,.16));border:1.5px solid rgba(232,132,58,.28);border-radius:99px;padding:3px 9px;font-size:.72rem;font-weight:800;color:var(--earth)}
.item.pledged{background:linear-gradient(90deg,rgba(245,200,66,.13),rgba(255,255,255,.96))}
.item-obs{font-size:.7rem;font-weight:700;color:var(--orange);background:rgba(232,132,58,.1);border-radius:6px;padding:2px 7px;align-self:center;white-space:nowrap;margin-left:4px}
.tag-pill{display:inline-block;font-size:.66rem;font-weight:800;border-radius:99px;padding:1px 7px;margin-top:2px}
.tag-essencial{background:rgba(192,57,43,.1);color:#c0392b}
.tag-importante{background:rgba(245,200,66,.2);color:#9a7d0a}
.tag-opcional{background:rgba(61,122,82,.12);color:var(--green)}
.aff-btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:12px 14px;border-radius:12px;font-family:'Baloo 2',cursive;font-size:.95rem;font-weight:900;text-decoration:none;transition:transform .15s,filter .15s;width:100%;margin-bottom:8px;box-shadow:0 3px 10px rgba(0,0,0,.08)}
.aff-btn:last-child{margin-bottom:0}
.aff-btn:hover{transform:translateY(-2px);filter:brightness(1.05)}
.aff-btn:active{transform:scale(.97)}
.aff-btn.aff-amazon{background:linear-gradient(135deg,#ff9900,#e47911);color:#fff}
.aff-btn.aff-ml{background:linear-gradient(135deg,#ffe600,#f5c842);color:var(--earth)}
.aff-modal-mascot{font-size:2.8rem;text-align:center;margin-bottom:4px;animation:mascotBounce 2s ease-in-out infinite}
.aff-modal-title{font-family:'Fredoka One',cursive;font-size:1.3rem;color:var(--earth);text-align:center;margin-bottom:4px}
.aff-modal-sub{font-size:.82rem;font-weight:700;color:var(--earth2);text-align:center;margin-bottom:16px;line-height:1.4}
.aff-pledged-wrap{margin-top:8px;background:linear-gradient(135deg,rgba(245,200,66,.1),rgba(232,132,58,.06));border:1.5px dashed rgba(232,132,58,.35);border-radius:12px;padding:8px 10px}
.aff-pledged-label{font-size:.68rem;font-weight:900;color:var(--earth2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:7px}
.aff-pledged-links{display:flex;flex-wrap:wrap;gap:7px}
.aff-pledged-link{flex:1;min-width:120px;display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:'Baloo 2',cursive;font-size:.85rem;font-weight:900;padding:9px 12px;border-radius:11px;text-decoration:none;transition:transform .15s,box-shadow .15s;box-shadow:0 3px 8px rgba(0,0,0,.1)}
.aff-pledged-link:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.15)}
.aff-pledged-link:active{transform:scale(.97)}
.aff-pledged-link.aff-amazon{background:linear-gradient(135deg,#ff9900,#e47911);color:#fff}
.aff-pledged-link.aff-ml{background:linear-gradient(135deg,#ffe600,#f5c518);color:var(--earth)}
.item-actions{display:flex;gap:4px;align-self:center;flex-wrap:wrap;justify-content:flex-end;max-width:190px}
.btn-item-action{width:24px;height:24px;border-radius:7px;border:none;font-size:.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,background .2s}
.item:hover .btn-item-action{opacity:1}
.btn-edit-item{background:rgba(61,122,82,.08);color:var(--green)}
.btn-edit-item:hover{background:rgba(61,122,82,.18)}
.btn-del-item{background:rgba(192,57,43,.08);color:var(--red)}
.btn-del-item:hover{background:rgba(192,57,43,.18)}
.btn-pledge-item{width:auto;min-width:78px;padding:0 8px;background:rgba(245,200,66,.22);color:var(--earth);font-family:'Baloo 2',cursive;font-size:.72rem;font-weight:900;opacity:1}
.btn-pledge-item:hover{background:rgba(245,200,66,.38)}
.btn-pledge-item.mine{background:rgba(192,57,43,.1);color:var(--red)}
.btn-pledge-item.mine:hover{background:rgba(192,57,43,.2)}
.item-gift-options{display:flex;flex-wrap:wrap;gap:7px;margin-top:7px}
.item-gift-options .btn-item-action{height:30px}
.lucky-wheel-wrap{margin-bottom:12px;display:flex;justify-content:center}
.btn-lucky-wheel{width:100%;max-width:360px;border:none;border-radius:18px;padding:12px 16px;background:linear-gradient(135deg,#F5C842 0%,#E8843A 55%,#B87333 100%);color:#fff;font-family:'Fredoka One',cursive;font-size:1rem;cursor:pointer;box-shadow:0 10px 26px rgba(232,132,58,.35);display:flex;align-items:center;justify-content:center;gap:8px;transition:transform .16s,box-shadow .16s}
.btn-lucky-wheel:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(232,132,58,.42)}
.btn-lucky-wheel:active{transform:scale(.97)}
.btn-lucky-wheel:disabled{opacity:.65;transform:none;cursor:not-allowed}
.wheel-modal{max-width:430px;overflow:hidden}
.wheel-stage{position:relative;display:flex;flex-direction:column;align-items:center;margin:6px 0 12px}
.wheel-pointer{position:absolute;top:-2px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:15px solid transparent;border-right:15px solid transparent;border-top:28px solid var(--earth);z-index:2;filter:drop-shadow(0 4px 6px rgba(46,26,14,.28))}
.lucky-wheel{width:min(290px,78vw);aspect-ratio:1;border-radius:50%;border:10px solid var(--white);box-shadow:0 18px 40px rgba(46,26,14,.24),inset 0 0 0 7px rgba(255,255,255,.34);background:conic-gradient(#F5C842 0 45deg,#5CAF77 45deg 90deg,#E8843A 90deg 135deg,#6BAED4 135deg 180deg,#B87333 180deg 225deg,#F5C842 225deg 270deg,#3D7A52 270deg 315deg,#E8843A 315deg 360deg);position:relative;transition:transform 3.1s cubic-bezier(.13,.78,.19,1)}
.lucky-wheel::before{content:'';position:absolute;inset:18%;border-radius:50%;background:rgba(255,252,243,.9);box-shadow:inset 0 0 0 3px rgba(184,115,51,.2)}
.lucky-wheel::after{content:'?';position:absolute;inset:36%;border-radius:50%;background:linear-gradient(135deg,var(--earth),var(--earth2));color:#fff;font-family:'Fredoka One',cursive;font-size:2.6rem;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(46,26,14,.28)}
.wheel-chip{position:absolute;left:50%;top:50%;width:86px;margin-left:-43px;margin-top:-14px;text-align:center;font-size:.64rem;font-weight:900;color:#fff;text-shadow:0 2px 5px rgba(46,26,14,.45);line-height:1.05;pointer-events:none}
.wheel-chip:nth-child(1){transform:rotate(18deg) translateY(-112px) rotate(-18deg)}
.wheel-chip:nth-child(2){transform:rotate(72deg) translateY(-112px) rotate(-72deg)}
.wheel-chip:nth-child(3){transform:rotate(126deg) translateY(-112px) rotate(-126deg)}
.wheel-chip:nth-child(4){transform:rotate(180deg) translateY(-112px) rotate(-180deg)}
.wheel-chip:nth-child(5){transform:rotate(234deg) translateY(-112px) rotate(-234deg)}
.wheel-chip:nth-child(6){transform:rotate(288deg) translateY(-112px) rotate(-288deg)}
.wheel-status{text-align:center;font-weight:800;color:var(--earth2);line-height:1.25;margin:10px 0 6px;min-height:42px}
.wheel-result{background:linear-gradient(135deg,rgba(245,200,66,.18),rgba(92,175,119,.12));border:2px dashed rgba(232,132,58,.35);border-radius:16px;padding:10px 12px;margin-top:8px;text-align:center;color:var(--earth);font-weight:900;display:none}
.wheel-result.visible{display:block;animation:checkPop .34s ease}
@media(max-width:640px){.btn-item-action{opacity:1}}
/* GIFT ALERT */
.gift-alert{max-width:700px;margin:10px auto 0;padding:0 12px;display:none}
.gift-alert.visible{display:block;animation:fadeUp .25s ease}
.gift-alert-card{background:linear-gradient(135deg,#fff8d8,#fff);border:2.5px solid rgba(232,132,58,.28);box-shadow:0 8px 24px rgba(184,115,51,.16);border-radius:18px;padding:12px 14px}
.gift-alert-title{display:flex;align-items:center;justify-content:space-between;gap:10px;font-family:'Fredoka One',cursive;color:var(--earth);font-size:.98rem;margin-bottom:7px}
.gift-alert-list{display:flex;flex-direction:column;gap:6px}
.gift-alert-row{display:flex;align-items:center;justify-content:space-between;gap:8px;background:rgba(255,255,255,.65);border-radius:12px;padding:7px 9px;font-size:.82rem;font-weight:700;color:var(--text)}
.gift-alert-person{color:var(--orange);font-weight:900}
.gift-alert-item{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gift-alert-btn{border:none;border-radius:99px;background:var(--red);color:var(--white);font-family:'Baloo 2',cursive;font-size:.72rem;font-weight:900;padding:4px 9px;cursor:pointer;white-space:nowrap}
.gift-alert-btn:hover{filter:brightness(.95)}
.contact-bar{max-width:700px;margin:10px auto 0;padding:0 12px;display:none}
.contact-card{background:var(--white);border:2px solid rgba(61,122,82,.16);border-radius:16px;padding:10px 12px;box-shadow:0 4px 16px var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:10px}
.contact-title{font-family:'Fredoka One',cursive;color:var(--earth);font-size:.9rem}
.contact-sub{font-size:.74rem;font-weight:700;color:var(--earth2);line-height:1.2}
.contact-actions{display:flex;gap:7px;flex-shrink:0}
.contact-btn{border:none;border-radius:99px;background:var(--green);color:var(--white);font-family:'Baloo 2',cursive;font-size:.75rem;font-weight:900;padding:6px 10px;text-decoration:none;white-space:nowrap}
.contact-btn.call{background:var(--earth2)}
@media(max-width:560px){.contact-card{align-items:flex-start;flex-direction:column}.contact-actions{width:100%}.contact-btn{text-align:center;flex:1}}
.family-card{max-width:700px;margin:10px auto 0;padding:0 12px;display:none}
.family-inner{background:rgba(255,252,243,.92);border:2px solid rgba(184,115,51,.14);border-radius:16px;padding:11px 13px;box-shadow:0 4px 16px var(--shadow)}
.family-title{font-family:'Fredoka One',cursive;color:var(--earth);font-size:.95rem;margin-bottom:5px}
.family-lines{display:flex;flex-wrap:wrap;gap:6px}
.family-pill{background:var(--sand);border-radius:99px;padding:4px 9px;font-size:.75rem;font-weight:800;color:var(--earth2)}
.event-card{max-width:700px;margin:10px auto 0;padding:0 12px}
.event-inner{background:var(--white);border:2px solid rgba(184,115,51,.14);border-radius:16px;padding:12px;box-shadow:0 4px 16px var(--shadow)}
.event-title{font-family:'Fredoka One',cursive;color:var(--earth);font-size:.98rem;margin-bottom:4px}
.event-meta{font-size:.78rem;font-weight:800;color:var(--earth2);line-height:1.25;margin-bottom:6px}
.event-note{font-size:.78rem;font-weight:700;color:var(--text);background:var(--sand);border-radius:10px;padding:7px 9px;margin-top:7px}
.event-actions{display:flex;gap:7px;flex-wrap:wrap;margin-top:9px}
.event-btn{border:none;border-radius:99px;padding:7px 11px;font-family:'Baloo 2',cursive;font-size:.78rem;font-weight:900;cursor:pointer;background:var(--green);color:var(--white)}
.event-btn.no{background:var(--red)}
.event-btn.maybe{background:var(--earth2)}
.event-status{font-size:.76rem;font-weight:900;color:var(--green);margin-top:7px}
.gift-list{margin-top:10px;display:flex;flex-direction:column;gap:7px}
.gift-row{background:var(--sand);border-radius:12px;padding:8px;font-size:.78rem;font-weight:800;color:var(--earth);display:flex;align-items:center;justify-content:space-between;gap:8px}
.gift-row small{display:block;color:var(--earth2);font-weight:700;margin-top:2px}
.gift-link{color:var(--green);font-weight:900;text-decoration:underline}
.address-preview{background:var(--sand);border-radius:12px;padding:10px;font-size:.86rem;font-weight:800;color:var(--earth);line-height:1.35;white-space:pre-line}
/* HISTORY */
.panel-wrap{max-width:700px;margin:10px auto 0;padding:0 12px}
.panel-toggle-btn{width:100%;background:var(--white);border:2.5px solid var(--sand2);border-radius:16px;padding:10px 16px;font-family:'Fredoka One',cursive;font-size:.92rem;color:var(--earth2);cursor:pointer;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px var(--shadow);transition:border .2s;margin-bottom:0}
.panel-toggle-btn:hover{border-color:var(--orange)}
.panel-badge{background:var(--orange);color:var(--white);border-radius:99px;font-size:.7rem;padding:2px 9px;font-family:'Baloo 2',cursive;font-weight:800}
.panel-body{display:none;margin-top:8px;animation:fadeUp .25s ease}
.panel-body.open{display:block}
.panel-card{background:var(--white);border-radius:16px;padding:14px;box-shadow:0 4px 16px var(--shadow);border:2px solid rgba(184,115,51,.12);max-height:300px;overflow-y:auto}
.history-card{max-height:260px;overflow-y:auto}
.log-entry{display:flex;align-items:flex-start;gap:9px;padding:7px 0;font-size:.8rem;border-bottom:1px dashed rgba(184,115,51,.15)}
.log-entry:last-child{border-bottom:none}
.log-avatar{width:27px;height:27px;min-width:27px;border-radius:50%;background:var(--yellow);color:var(--earth);font-weight:800;font-size:.75rem;display:flex;align-items:center;justify-content:center}
.log-check{color:var(--green);font-weight:700}
.log-uncheck{color:var(--red);font-weight:700}
.log-add{color:var(--sky);font-weight:700}
.log-del{color:#999;font-weight:700}
.log-time{font-size:.68rem;color:#bbb;font-weight:600;margin-top:1px}
/* ADMIN */
.admin-user-row{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:10px;background:var(--sand);margin-bottom:6px}
.admin-user-info{font-size:.82rem;font-weight:700;color:var(--earth)}
.admin-user-email{font-size:.72rem;color:var(--earth2);font-weight:600}
.btn-del-user{background:rgba(192,57,43,.1);border:none;border-radius:8px;padding:5px 10px;color:var(--red);font-family:'Baloo 2',cursive;font-size:.75rem;font-weight:700;cursor:pointer}
.btn-del-user:hover{background:rgba(192,57,43,.22)}
/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(46,26,14,.55);backdrop-filter:blur(6px);z-index:400;display:none;align-items:center;justify-content:center;padding:16px}
.modal-overlay.open{display:flex;animation:fadeIn .2s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{background:var(--white);border-radius:26px;padding:26px 22px 22px;max-width:400px;width:100%;box-shadow:0 24px 64px rgba(0,0,0,.3);border:3px solid var(--earth2);animation:modalIn .25s cubic-bezier(.4,0,.2,1)}
@keyframes modalIn{from{transform:scale(.9) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.modal-title{font-family:'Fredoka One',cursive;font-size:1.35rem;color:var(--earth);margin-bottom:14px}
.modal-actions{display:flex;gap:9px;margin-top:14px}
.btn-cancel{flex:1;background:var(--sand);border:2px solid var(--sand2);border-radius:11px;padding:10px;font-family:'Fredoka One',cursive;font-size:.92rem;color:var(--earth2);cursor:pointer}
.btn-cancel:hover{background:var(--sand2)}
.btn-confirm{flex:1;background:linear-gradient(135deg,var(--orange),var(--earth2));border:none;border-radius:11px;padding:10px;font-family:'Fredoka One',cursive;font-size:.92rem;color:var(--white);cursor:pointer;box-shadow:0 4px 14px rgba(232,132,58,.35);transition:transform .15s}
.btn-confirm:hover{transform:translateY(-1px)}
/* LOADING OVERLAY */
.loading-overlay{position:fixed;inset:0;background:rgba(247,237,218,.85);z-index:500;display:none;align-items:center;justify-content:center;flex-direction:column;gap:12px}
.loading-overlay.visible{display:flex}
.loading-giraffe{font-size:3rem;animation:mascotBounce 1s ease-in-out infinite}
.loading-text{font-family:'Fredoka One',cursive;font-size:1.1rem;color:var(--earth)}
/* TOAST */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--earth);color:var(--white);font-family:'Fredoka One',cursive;font-size:.95rem;padding:11px 22px;border-radius:99px;box-shadow:0 8px 28px var(--shadow);z-index:200;transition:transform .35s cubic-bezier(.4,0,.2,1);white-space:nowrap;max-width:92vw;text-align:center}
.toast.show{transform:translateX(-50%) translateY(0)}
.terms-check{display:flex;align-items:flex-start;gap:9px;background:rgba(61,122,82,.08);border:2px solid rgba(61,122,82,.14);border-radius:12px;padding:9px 11px;margin:8px 0 12px}
.terms-check input{margin-top:4px;accent-color:var(--green)}
.terms-check label{font-size:.78rem;line-height:1.25;font-weight:700;color:var(--earth)}
.terms-link{border:none;background:none;color:var(--green);font-family:'Baloo 2',cursive;font-size:.78rem;font-weight:900;text-decoration:underline;cursor:pointer;padding:0}
.terms-content{max-height:52vh;overflow:auto;background:var(--sand);border-radius:14px;padding:12px;font-size:.88rem;font-weight:600;color:var(--earth);white-space:pre-wrap}
.cookie-banner{position:fixed;left:50%;bottom:18px;transform:translateX(-50%) translateY(120%);width:min(640px,calc(100vw - 24px));background:var(--white);border:2.5px solid var(--earth2);border-radius:18px;box-shadow:0 18px 48px rgba(46,26,14,.28);z-index:220;padding:14px;display:flex;align-items:center;gap:12px;transition:transform .3s ease}
.cookie-banner.visible{transform:translateX(-50%) translateY(0)}
.cookie-text{flex:1;font-size:.82rem;font-weight:700;color:var(--earth);line-height:1.25}
.cookie-actions{display:flex;gap:8px;flex-shrink:0}
.btn-cookie{border:none;border-radius:99px;padding:8px 13px;font-family:'Fredoka One',cursive;font-size:.78rem;cursor:pointer}
.btn-cookie.primary{background:var(--green);color:var(--white)}
.btn-cookie.secondary{background:var(--sand);color:var(--earth2);border:2px solid var(--sand2)}
/* CRIAR ENXOVAL */
#screen-create.active{display:flex;min-height:100vh;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px}
.create-card{background:var(--white);border-radius:32px;padding:36px 30px 28px;max-width:420px;width:100%;box-shadow:0 16px 48px var(--shadow);border:3px solid var(--green2);position:relative;overflow:hidden}
.create-card::before{content:'';position:absolute;top:0;left:0;right:0;height:6px;background:repeating-linear-gradient(90deg,var(--green2) 0,var(--green2) 20px,var(--yellow) 20px,var(--yellow) 40px,var(--orange) 40px,var(--orange) 60px)}
.create-title{font-family:'Fredoka One',cursive;font-size:2rem;text-align:center;color:var(--earth);line-height:1.1;margin-bottom:2px}
.create-title span{color:var(--green)}
.create-sub{text-align:center;font-size:.85rem;color:var(--earth2);font-weight:600;margin-bottom:18px}
.create-back{background:none;border:none;color:var(--earth2);font-family:'Baloo 2',cursive;font-size:.82rem;font-weight:700;cursor:pointer;margin-top:14px;text-decoration:underline}
.secret-key-box{background:var(--sand);border:2px dashed var(--earth2);border-radius:14px;padding:12px 14px;margin-top:14px;text-align:center}
.secret-key-box strong{font-family:'Fredoka One',cursive;font-size:1.1rem;color:var(--earth);display:block;margin-bottom:4px}
.secret-key-value{font-family:'Baloo 2',cursive;font-size:1.3rem;font-weight:900;color:var(--orange);letter-spacing:2px;word-break:break-all}
.secret-key-hint{font-size:.72rem;color:var(--earth2);font-weight:700;margin-top:5px;line-height:1.3}
.btn-criar{width:100%;background:linear-gradient(135deg,var(--green),var(--green2));border:none;border-radius:14px;padding:13px;font-family:'Fredoka One',cursive;font-size:1.1rem;color:var(--white);cursor:pointer;box-shadow:0 6px 18px rgba(61,122,82,.35);transition:transform .15s}
.btn-criar:hover{transform:translateY(-2px)}
.btn-criar:disabled{opacity:.6;transform:none;cursor:not-allowed}
.btn-criar-link{width:100%;background:rgba(61,122,82,.1);border:2px solid var(--green2);border-radius:14px;padding:11px;font-family:'Fredoka One',cursive;font-size:.95rem;color:var(--green);cursor:pointer;margin-top:10px;transition:background .15s}
.btn-criar-link:hover{background:rgba(61,122,82,.18)}
/* TEMPLATE CHOICE */
.tmpl-grid{display:flex;flex-direction:column;gap:10px;margin:20px 0}
.tmpl-opt{border:2.5px solid var(--sand2);border-radius:18px;padding:16px 16px 14px;cursor:pointer;background:var(--white);transition:all .22s;position:relative;text-align:left}
.tmpl-opt:hover{border-color:var(--orange);transform:translateY(-2px);box-shadow:0 8px 24px var(--shadow)}
.tmpl-rec{border-color:rgba(92,175,119,.6);background:linear-gradient(135deg,rgba(92,175,119,.07),rgba(245,200,66,.04))}
.tmpl-opt-head{display:flex;align-items:flex-start;gap:11px;margin-bottom:8px}
.tmpl-opt-icon{font-size:2rem;line-height:1;width:44px;text-align:center;flex-shrink:0;margin-top:2px}
.tmpl-opt-title{font-family:'Fredoka One',cursive;font-size:1.08rem;color:var(--earth);line-height:1.2}
.tmpl-rec-badge{display:inline-block;background:rgba(61,122,82,.12);color:var(--green);border-radius:99px;padding:2px 9px;font-size:.65rem;font-weight:900;letter-spacing:.3px;text-transform:uppercase;margin-top:4px}
.tmpl-opt-desc{font-size:.8rem;font-weight:600;color:var(--earth2);line-height:1.6;padding-left:55px}
.tmpl-arrow{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:1.4rem;color:var(--sand2);transition:all .2s;font-family:'Fredoka One',cursive}
.tmpl-opt:hover .tmpl-arrow{color:var(--orange);right:11px}
.sex-grid{display:flex;gap:8px;margin-bottom:14px}
.sex-btn{flex:1;border:2.5px solid var(--sand2);border-radius:12px;padding:9px 4px;text-align:center;cursor:pointer;background:var(--sand);font-family:'Fredoka One',cursive;font-size:.88rem;color:var(--earth2);transition:all .2s;line-height:1.3}
.sex-btn.active{border-color:var(--orange);background:rgba(232,132,58,.12);color:var(--earth)}
.theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.theme-card{border:2.5px solid var(--sand2);border-radius:14px;padding:10px 4px;text-align:center;cursor:pointer;background:var(--sand);transition:all .2s}
.theme-card.active{border-color:var(--orange);background:rgba(232,132,58,.12)}
.theme-card-emoji{font-size:1.7rem;display:block;margin-bottom:2px}
.theme-card-name{font-family:'Fredoka One',cursive;font-size:.72rem;color:var(--earth);display:block;line-height:1.2}
.theme-card-gender{font-size:.6rem;color:var(--earth2);font-weight:800;text-transform:uppercase;letter-spacing:.5px}
@media(max-width:560px){.cookie-banner{align-items:stretch;flex-direction:column}.cookie-actions{justify-content:flex-end}}
/* PWA INSTALL CARD */
#screen-login.active{padding:20px 16px 32px}
.pwa-card{max-width:420px;width:100%;margin-top:14px;background:linear-gradient(140deg,var(--earth) 0%,var(--earth2) 55%,var(--orange) 100%);border-radius:24px;padding:20px 20px 18px;box-shadow:0 14px 44px rgba(232,132,58,.45),0 4px 14px rgba(0,0,0,.18);position:relative;animation:pwaIn .55s cubic-bezier(.34,1.56,.64,1) .35s both}
@keyframes pwaIn{from{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:none}}
.pwa-dismiss{position:absolute;top:12px;right:12px;width:26px;height:26px;background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.72rem;color:rgba(255,255,255,.8);transition:background .15s;line-height:1;flex-shrink:0}
.pwa-dismiss:hover{background:rgba(255,255,255,.3)}
.pwa-head{display:flex;align-items:center;gap:12px;margin-bottom:14px;padding-right:20px}
.pwa-app-icon{width:56px;height:56px;border-radius:14px;box-shadow:0 4px 14px rgba(0,0,0,.3);flex-shrink:0;object-fit:cover}
.pwa-app-name{font-family:'Fredoka One',cursive;font-size:1.22rem;color:#fff;line-height:1.1}
.pwa-app-sub{font-size:.7rem;color:rgba(255,255,255,.65);font-weight:700;margin-top:1px}
.pwa-stars{color:var(--yellow);font-size:.82rem;letter-spacing:-1px;margin-top:3px}
.pwa-feats{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.pwa-feat{display:flex;align-items:center;gap:10px;font-size:.83rem;font-weight:700;color:rgba(255,255,255,.92);line-height:1.2}
.pwa-feat .feat-icon{font-size:1rem;width:28px;height:28px;background:rgba(255,255,255,.15);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pwa-btn{width:100%;background:var(--white);border:none;border-radius:14px;padding:13px 16px;font-family:'Fredoka One',cursive;font-size:1.05rem;color:var(--earth);cursor:pointer;box-shadow:0 4px 18px rgba(0,0,0,.22);transition:transform .15s;display:flex;align-items:center;justify-content:center;gap:8px;position:relative;overflow:hidden}
.pwa-btn::after{content:'';position:absolute;inset:0;border-radius:14px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.55) 50%,transparent 100%);transform:translateX(-100%);animation:btnShimmer 2.8s ease-in-out 1.5s infinite}
@keyframes btnShimmer{0%,25%{transform:translateX(-100%)}65%,100%{transform:translateX(160%)}}
.pwa-btn:hover:not(:disabled){transform:translateY(-2px)}
.pwa-btn.pwa-pending{opacity:.75;cursor:wait}
.pwa-btn.pwa-pending::after{display:none}
.pwa-waiting{margin-top:7px;text-align:center;font-size:.72rem;font-weight:700;color:rgba(255,255,255,.6);letter-spacing:.3px}
.pwa-waiting.hidden{display:none}
.pwa-ios-tip{margin-top:12px;background:rgba(255,255,255,.14);border:1.5px dashed rgba(255,255,255,.35);border-radius:12px;padding:10px 14px;font-size:.8rem;font-weight:700;color:rgba(255,255,255,.9);text-align:center;line-height:1.6}
.pwa-ios-tip strong{color:#fff}
.pwa-ios-steps{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:6px;font-size:.75rem}
.pwa-ios-steps span{background:rgba(255,255,255,.2);border-radius:99px;padding:2px 9px;color:#fff;font-weight:800}
/* CONFETTI */
.confetti-piece{position:fixed;pointer-events:none;z-index:300;border-radius:2px;animation:confettiFall linear forwards}
@keyframes confettiFall{0%{opacity:1;transform:translateY(0) rotate(0deg)}100%{opacity:0;transform:translateY(80vh) rotate(720deg)}}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--sand)}
::-webkit-scrollbar-thumb{background:var(--earth2);border-radius:99px}

/* LEGIBILIDADE */
body{font-size:17px;line-height:1.45}
.login-card,.create-card{max-width:460px}
.login-sub,.create-sub,.header-tag{font-size:1rem;line-height:1.45}
.field-label{font-size:1rem;line-height:1.35;margin-bottom:6px}
.field-input{font-size:1.08rem;padding:13px 15px;line-height:1.35}
.form-tab,.btn-primary,.btn-criar{font-size:1.16rem;padding:14px}
.error-msg{font-size:1rem;line-height:1.35;padding:10px 14px}
.tab-btn{font-size:1rem;padding:9px 15px}
.tab-btn .tbadge,.panel-badge{font-size:.86rem}
.btn-add-item{font-size:1rem;padding:9px 18px}
.cat-header{padding:13px 16px}
.cat-title-text{font-size:1.14rem;line-height:1.25}
.cat-pct{font-size:.95rem;padding:3px 10px}
.item{gap:11px;padding:12px 8px}
.check-box{width:31px;height:31px;min-width:31px}
.check-icon{font-size:1.08rem}
.item-label{font-size:1.08rem;line-height:1.45}
.item-who,.item-obs,.pledge-note,.btn-pledge-item{font-size:.92rem;line-height:1.3}
.tag-pill{font-size:.84rem;padding:2px 8px}
.btn-item-action{width:30px;height:30px;font-size:1rem}
.gift-alert-title,.contact-title,.family-title,.event-title{font-size:1.1rem;line-height:1.3}
.gift-alert-row,.contact-sub,.family-pill,.event-meta,.event-note,.event-btn,.gift-row,.pix-row,.pix-value,.panel-toggle-btn,.log-entry,.admin-user-info,.admin-user-email{font-size:1rem;line-height:1.35}
.address-preview,.terms-content,.cookie-text{font-size:1rem;line-height:1.45}
.log-time,.secret-key-hint,.pwa-app-sub,.pwa-waiting{font-size:.9rem}
.modal-title{font-size:1.55rem}
.btn-cancel,.btn-confirm,.btn-cookie,.btn-criar-link{font-size:1rem;padding:12px}
.terms-check label,.terms-link{font-size:1rem;line-height:1.35}
.create-back{font-size:1rem}
.tmpl-opt-title{font-size:1.18rem}
.tmpl-rec-badge{font-size:.82rem}
.tmpl-opt-desc{font-size:1rem;line-height:1.45}
.sex-btn{font-size:1rem;padding:11px 4px}
.theme-card-name{font-size:.9rem}
.theme-card-gender{font-size:.78rem}
.pwa-app-name{font-size:1.35rem}
.pwa-feat{font-size:1rem;line-height:1.35}
.pwa-ios-tip,.pwa-ios-steps{font-size:.95rem}

/* VISUAL DE DIVULGACAO / TEMAS */
:root{
  --paper:#fffaf0;
  --surface:rgba(255,252,243,.92);
  --surface-strong:#fffaf0;
  --line:rgba(122,79,45,.16);
  --line-strong:rgba(232,132,58,.34);
  --scene-a:rgba(255,250,237,.94);
  --scene-b:rgba(232,132,58,.18);
  --scene-c:rgba(139,177,104,.22);
  --theme-soft:rgba(139,177,104,.12);
  --theme-glow:rgba(232,132,58,.24);
}
body{
  background:
    radial-gradient(circle at 12% 8%,var(--scene-c),transparent 27rem),
    radial-gradient(circle at 90% 18%,var(--scene-b),transparent 24rem),
    linear-gradient(180deg,var(--scene-a) 0%,var(--sand) 48%,rgba(122,79,45,.12) 100%);
}
.jungle-bg{opacity:.95}
.jungle-bg::before,.jungle-bg::after{
  content:'';
  position:absolute;
  width:420px;
  height:420px;
  border-radius:50%;
  pointer-events:none;
}
.jungle-bg::before{left:-180px;bottom:8%;background:radial-gradient(circle,var(--scene-c),transparent 68%)}
.jungle-bg::after{right:-160px;top:10%;background:radial-gradient(circle,var(--scene-b),transparent 70%)}
.leaf{
  opacity:.13;
  filter:drop-shadow(0 8px 18px rgba(46,26,14,.12));
}
.leaf.hero-float{opacity:.22;filter:drop-shadow(0 12px 24px rgba(46,26,14,.14))}
#screen-login.active,#screen-create.active{
  justify-content:flex-start;
  padding-top:clamp(18px,5vh,58px);
  background:
    linear-gradient(180deg,rgba(255,250,237,.48),rgba(247,237,218,.12)),
    radial-gradient(circle at 50% 88%,rgba(122,79,45,.16),transparent 34rem);
}
.login-card,.create-card{
  background:linear-gradient(180deg,rgba(255,252,243,.96),rgba(255,247,229,.92));
  border:1.5px solid rgba(255,255,255,.74);
  box-shadow:0 24px 70px rgba(46,26,14,.22),0 2px 0 rgba(255,255,255,.75) inset;
  border-radius:28px;
}
.login-card::before,.create-card::before{
  height:9px;
  background:linear-gradient(90deg,var(--green),var(--orange),var(--yellow));
  opacity:.95;
}
.login-card::after,.create-card::after{
  content:'';
  position:absolute;
  inset:10px;
  border:1px dashed rgba(184,115,51,.16);
  border-radius:22px;
  pointer-events:none;
}
.login-mascot{
  width:92px;
  height:92px;
  margin:0 auto 8px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:26px;
  background:linear-gradient(145deg,var(--theme-soft),rgba(255,255,255,.82));
  box-shadow:0 12px 26px rgba(46,26,14,.12);
}
.login-title,.create-title{
  font-size:2.35rem;
  letter-spacing:0;
  text-shadow:0 2px 0 rgba(255,255,255,.75);
}
.login-sub,.create-sub{
  color:var(--earth);
  background:rgba(255,255,255,.52);
  border:1px solid var(--line);
  border-radius:999px;
  padding:7px 12px;
  margin:8px auto 18px;
  width:max-content;
  max-width:100%;
}
.form-tabs,.field-input,.sex-btn,.theme-card,.tmpl-opt{
  background:rgba(255,255,255,.66);
  border-color:var(--line);
  box-shadow:0 1px 0 rgba(255,255,255,.9) inset;
}
.field-input:focus{
  box-shadow:0 0 0 4px var(--theme-glow);
}
.btn-primary,.btn-criar,.btn-confirm{
  background:linear-gradient(135deg,var(--orange),var(--earth2));
  border-radius:18px;
  box-shadow:0 12px 28px var(--theme-glow);
}
.btn-criar,.btn-add-item,.contact-btn,.event-btn,.btn-cookie.primary{
  background:linear-gradient(135deg,var(--green),var(--green2));
}
.btn-criar-link{
  background:rgba(255,255,255,.66);
  border-color:var(--line-strong);
  box-shadow:0 10px 24px rgba(46,26,14,.08);
}
.theme-grid{gap:10px}
.theme-card{
  min-height:96px;
  border-radius:18px;
  position:relative;
  overflow:hidden;
}
.theme-card::after{
  content:'';
  position:absolute;
  inset:auto -20px -34px auto;
  width:82px;
  height:82px;
  border-radius:50%;
  background:var(--theme-soft);
}
.theme-card.active{
  background:linear-gradient(145deg,rgba(255,255,255,.92),var(--theme-soft));
  border-color:var(--orange);
  box-shadow:0 10px 24px var(--theme-glow);
}
.theme-card-emoji{
  position:relative;
  z-index:1;
  font-size:2rem;
}
.pwa-card{
  background:
    radial-gradient(circle at 88% 12%,rgba(255,255,255,.18),transparent 9rem),
    linear-gradient(140deg,var(--earth),var(--earth2) 55%,var(--orange));
  border:1px solid rgba(255,255,255,.22);
}
#screen-app.active{
  min-height:100vh;
  padding-bottom:96px;
}
.app-header{
  background:
    radial-gradient(circle at 92% 0%,rgba(255,255,255,.18),transparent 11rem),
    linear-gradient(160deg,var(--green) 0%,var(--green2) 52%,var(--earth2) 100%);
  border-bottom-left-radius:28px;
  border-bottom-right-radius:28px;
  box-shadow:0 18px 44px rgba(46,26,14,.18);
}
.header-top,.header-tagline{
  max-width:760px;
}
.header-logo-icon{
  width:48px;
  height:48px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:16px;
  background:rgba(255,255,255,.18);
}
.header-user-badge{
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.2);
  border-radius:999px;
  padding:5px 6px;
}
.inicio-hero,.contact-card,.family-inner,.event-inner,.gift-alert-card,.panel-card,.cat-card{
  background:linear-gradient(180deg,rgba(255,252,243,.96),rgba(255,248,236,.92));
  border:1.5px solid rgba(255,255,255,.76);
  box-shadow:0 16px 38px rgba(46,26,14,.12);
}
.inicio-hero{
  margin-top:16px;
  border-radius:28px;
  padding:18px;
}
.circ-wrap{
  background:rgba(255,255,255,.72);
  border-radius:50%;
  padding:8px;
  box-shadow:0 10px 26px rgba(46,26,14,.1);
}
.inicio-title{
  font-size:1.35rem;
}
.progress-track{
  background:rgba(237,217,176,.68);
}
.contact-card,.family-inner,.event-inner,.gift-alert-card,.panel-card{
  border-radius:22px;
}
.tabs-wrap{
  background:rgba(255,252,243,.56);
  border:1px solid rgba(255,255,255,.72);
  border-radius:999px;
  padding:8px;
  box-shadow:0 12px 30px rgba(46,26,14,.08);
}
.tabs-shell{
  max-width:700px;
  margin:14px auto 0;
  padding:0 12px;
  position:relative;
}
.tabs-shell .tabs-wrap{
  max-width:none;
  margin:0;
  padding-right:42px;
  scroll-behavior:smooth;
}
.tabs-hint{
  position:absolute;
  top:50%;
  width:34px;
  height:34px;
  border:none;
  border-radius:50%;
  transform:translateY(-50%) scale(.92);
  z-index:4;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Fredoka One',cursive;
  font-size:1rem;
  color:var(--white);
  background:linear-gradient(135deg,var(--orange),var(--earth2));
  box-shadow:0 10px 24px var(--theme-glow);
  opacity:0;
  pointer-events:none;
  transition:opacity .2s,transform .2s;
}
.tabs-hint.visible{
  opacity:1;
  pointer-events:auto;
  transform:translateY(-50%) scale(1);
}
.tabs-hint.left{left:18px}
.tabs-hint.right{right:18px}
.tabs-shell::before,.tabs-shell::after{
  content:'';
  position:absolute;
  top:2px;
  bottom:2px;
  width:66px;
  z-index:3;
  pointer-events:none;
  opacity:0;
  transition:opacity .2s;
}
.tabs-shell::before{
  left:12px;
  border-radius:999px 0 0 999px;
  background:linear-gradient(90deg,var(--paper),rgba(255,250,240,0));
}
.tabs-shell::after{
  right:12px;
  border-radius:0 999px 999px 0;
  background:linear-gradient(270deg,var(--paper),rgba(255,250,240,0));
}
.tabs-shell.has-left::before,.tabs-shell.has-right::after{opacity:.95}
.tab-btn{
  border:none;
  border-radius:999px;
  box-shadow:none;
}
.tab-btn.active{
  background:linear-gradient(135deg,var(--orange),var(--earth2));
}
.cat-card{
  border-radius:24px;
  overflow:hidden;
}
.cat-header{
  background:linear-gradient(90deg,var(--theme-soft),rgba(255,255,255,.42));
  border-bottom:1px dashed rgba(184,115,51,.18);
}
.item{
  background:rgba(255,255,255,.46);
  border:1px solid rgba(184,115,51,.09);
  margin:8px 0;
  border-radius:16px;
}
.item+.item{border-top:1px solid rgba(184,115,51,.09)}
.item:hover{background:rgba(255,255,255,.72)}
.bottom-nav{
  left:50%;
  right:auto;
  bottom:12px;
  transform:translateX(-50%);
  width:min(520px,calc(100vw - 24px));
  border:1px solid rgba(255,255,255,.76);
  border-radius:26px;
  background:rgba(255,252,243,.92);
  box-shadow:0 18px 44px rgba(46,26,14,.22);
  overflow:hidden;
  padding:6px 6px calc(6px + env(safe-area-inset-bottom));
}
.bnav-btn{
  border-radius:20px;
}
.bnav-btn.active{
  background:var(--theme-soft);
}
.bnav-btn.active .bnav-label{color:var(--earth)}
.bnav-btn.active .bnav-icon{filter:drop-shadow(0 6px 10px var(--theme-glow))}
.modal{
  background:linear-gradient(180deg,rgba(255,252,243,.98),rgba(255,247,229,.96));
  border:1.5px solid rgba(255,255,255,.78);
  box-shadow:0 26px 80px rgba(46,26,14,.32);
}
@media(max-width:560px){
  body{font-size:18px}
  #screen-login.active,#screen-create.active{justify-content:flex-start;padding:18px 12px 32px}
  .login-card,.create-card{padding:30px 20px 24px;border-radius:24px}
  .login-title{font-size:2rem}
  .create-title{font-size:1.85rem}
  .header-user-badge,.btn-logout{font-size:1rem}
  .header-username{font-size:1rem}
  .app-content,.tabs-wrap,.progress-wrap{max-width:760px}
  .item{padding:13px 8px}
  .item-actions{flex-direction:row;max-width:100%;justify-content:flex-start}
  .btn-pledge-item{min-width:92px;padding:5px 9px}
  .tmpl-opt-desc{padding-left:0}
}

/* PREGNANCY CARD */
.pregnancy-card{max-width:700px;margin:10px auto 0;padding:0 12px}
.pregnancy-inner{
  background:linear-gradient(135deg,rgba(255,192,203,.18),rgba(255,252,243,.95));
  border:1.5px solid rgba(255,182,193,.45);
  border-radius:22px;
  padding:14px 16px;
  display:flex;align-items:center;gap:14px;
  box-shadow:0 8px 24px rgba(46,26,14,.1);
}
.pregnancy-icon{font-size:2.4rem;line-height:1;flex-shrink:0}
.pregnancy-info{flex:1;min-width:0}
.pregnancy-weeks-text{
  font-family:'Fredoka One',cursive;
  font-size:1.25rem;color:var(--earth);line-height:1.1;
  margin-bottom:2px;
}
.pregnancy-detail{
  font-size:.82rem;font-weight:800;color:var(--earth2);
  margin-bottom:8px;
}
.pregnancy-bar-wrap{
  background:rgba(184,115,51,.15);
  border-radius:99px;height:8px;overflow:hidden;
}
.pregnancy-bar-fill{
  height:100%;
  background:linear-gradient(90deg,#f8a4c0,#e8843a);
  border-radius:99px;
  transition:width .7s cubic-bezier(.4,0,.2,1);
}
.months-weeks-hint{
  font-size:.88rem;font-weight:800;color:var(--green);
  min-height:20px;
  background:rgba(61,122,82,.1);
  border-radius:8px;
  padding:4px 10px;
  display:none;
}
.months-weeks-hint.visible{display:block}

/* WHEEL WELCOME OVERLAY */
.wheel-welcome-overlay{
  position:fixed;inset:0;z-index:600;
  background:rgba(46,26,14,.72);
  backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;
  padding:20px;
}
.wheel-welcome-overlay.open{
  display:flex;
  animation:fadeIn .35s ease;
}
.wheel-welcome-card{
  background:linear-gradient(180deg,rgba(255,252,243,.98),rgba(255,247,229,.96));
  border:2px solid rgba(255,255,255,.76);
  box-shadow:0 28px 80px rgba(46,26,14,.38);
  border-radius:32px;
  padding:32px 28px 26px;
  max-width:380px;width:100%;
  text-align:center;
  position:relative;
  overflow:hidden;
  animation:modalIn .4s cubic-bezier(.34,1.56,.64,1);
}
.wheel-welcome-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:8px;
  background:linear-gradient(90deg,var(--green),var(--orange),var(--yellow));
}
.wheel-welcome-wheel{
  width:130px;height:130px;
  border-radius:50%;
  background:conic-gradient(#F5C842 0 45deg,#5CAF77 45deg 90deg,#E8843A 90deg 135deg,#6BAED4 135deg 180deg,#B87333 180deg 225deg,#F5C842 225deg 270deg,#3D7A52 270deg 315deg,#E8843A 315deg 360deg);
  border:8px solid var(--white);
  box-shadow:0 12px 32px rgba(46,26,14,.22);
  margin:8px auto 20px;
  animation:welcomeWheelSpin 8s linear infinite;
  position:relative;
}
.wheel-welcome-wheel::after{
  content:'🎡';
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-size:2.4rem;
  background:rgba(255,252,243,.88);
  border-radius:50%;
  margin:14px;
}
@keyframes welcomeWheelSpin{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}
.wheel-welcome-title{
  font-family:'Fredoka One',cursive;
  font-size:1.55rem;color:var(--earth);
  line-height:1.2;margin-bottom:8px;
}
.wheel-welcome-title span{color:var(--orange)}
.wheel-welcome-sub{
  font-size:.95rem;font-weight:700;
  color:var(--earth2);line-height:1.45;
  margin-bottom:22px;
}
.wheel-welcome-btn{
  width:100%;border:none;border-radius:18px;
  padding:16px;
  background:linear-gradient(135deg,#F5C842,#E8843A,#B87333);
  color:#fff;
  font-family:'Fredoka One',cursive;font-size:1.3rem;
  cursor:pointer;
  box-shadow:0 12px 32px rgba(232,132,58,.45);
  animation:welcomeBtnPulse 1.6s ease-in-out infinite;
  transition:transform .15s;
  margin-bottom:14px;
}
.wheel-welcome-btn:hover{transform:scale(1.04)}
.wheel-welcome-btn:active{transform:scale(.97);animation:none}
@keyframes welcomeBtnPulse{
  0%,100%{box-shadow:0 12px 32px rgba(232,132,58,.45),0 0 0 0 rgba(232,132,58,.35)}
  50%{box-shadow:0 16px 40px rgba(232,132,58,.55),0 0 0 10px rgba(232,132,58,0)}
}
.wheel-welcome-skip{
  background:none;border:none;
  color:var(--earth2);font-family:'Baloo 2',cursive;
  font-size:.9rem;font-weight:700;
  text-decoration:underline;cursor:pointer;
  opacity:.7;
}
.wheel-welcome-skip:hover{opacity:1}