/* Mobile-first base styles */
html{-webkit-text-size-adjust:100%}
body{background:#fafaf4}
.app-header{backdrop-filter:saturate(180%) blur(8px)}
/* Título dinámico por pestaña */
#pageTitle{display:flex; align-items:center; gap:6px; font-weight:600; transition:opacity .2s ease, transform .2s ease}
#pageTitle i{font-size:1rem}
.title-swap{opacity:0; transform:translateY(4px)}
.screen{height:calc(100dvh - 56px - 64px); overflow:auto; padding-bottom:calc(72px + env(safe-area-inset-bottom,0px))}
/* View color themes */
#v-home{--view-accent:#dea750}
#v-diary{--view-accent:#398a99}
#v-goals{--view-accent:#a53436}
#v-progress{--view-accent:#b7b379}

/* Accent usage */
.view-colored h6,.view-colored .fw-semibold,.view-colored .badge.rounded-pill.bg-primary{color:var(--view-accent)!important}
.view-colored .badge.rounded-pill.bg-primary{background:var(--view-accent)!important}
.view-colored .btn-outline-primary{border-color:var(--view-accent);color:var(--view-accent)}
.view-colored .btn-outline-primary:hover{background:var(--view-accent);color:#fff}
.view-colored .table thead th{color:var(--view-accent)!important}
.view-colored .bebidas-table tbody tr:hover td{background:color-mix(in srgb,var(--view-accent) 12%, #fff)}

/* Dynamic header accent transition */
.app-header{transition:background .3s ease}
.header-accent-home{background:linear-gradient(90deg,#dea75022,#dea75008);}
.header-accent-diary{background:linear-gradient(90deg,#398a9922,#398a9908);}
.header-accent-goals{background:linear-gradient(90deg,#a5343622,#a5343608);}
.header-accent-progress{background:linear-gradient(90deg,#b7b37922,#b7b37908);}
.dock{backdrop-filter:saturate(180%) blur(8px)}
.dock.navbar{padding:0; border-top:none !important}
/* Bottom nav: icon-only, centered with active indicator */
.dock .container-fluid{position:relative}
.dock .nav{gap:0; align-items:stretch}
.dock .nav-item{flex:1}
.dock .nav-link{display:flex; align-items:center; justify-content:center; padding:0; height:56px; color:#6c757d; transition:color .2s ease}
.dock .nav-link, .dock .nav-link:hover, .dock .nav-link.active{border:0 !important}
.dock .nav-link i{font-size:1.25rem; line-height:1; transition:transform .2s ease, filter .2s ease, color .2s ease}
.dock .nav-link.active{color:var(--view-accent,#dea750); position:relative}
.dock .nav-link.active i{color:var(--view-accent,#dea750); transform:scale(1.12); filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}
.dock .nav-link.active::after{content:''; position:absolute; bottom:6px; left:50%; transform:translateX(-50%); width:32px; height:32px; background:color-mix(in srgb,var(--view-accent) 18%, #ffffff); border-radius:50%; z-index:-1;}
.dock .nav-link:active i{transform:scale(.94)}
.dock .nav-indicator{position:absolute; top:0; left:0; height:0; width:25%; background:transparent; transition:none}

/* Accent gradient for dock background per view */
.dock-accent-home{background:linear-gradient(180deg,#dea75010,#ffffff 60%)!important}
.dock-accent-diary{background:linear-gradient(180deg,#398a9910,#ffffff 60%)!important}
.dock-accent-goals{background:linear-gradient(180deg,#a5343610,#ffffff 60%)!important}
.dock-accent-progress{background:linear-gradient(180deg,#b7b37910,#ffffff 60%)!important}
/* (FAB eliminado) */
.card{border-radius:14px}
.list-group-item{border:0;border-bottom:1px solid #eef2f7}
.list-group-item:last-child{border-bottom:0}
/* Bebidas table styling inside diary entries */
.bebidas-table thead th{font-size:.65rem; letter-spacing:.5px; text-transform:uppercase; font-weight:600; color:#6c757d; padding-top:0;}
.bebidas-table tbody td{font-size:.75rem; padding:.25rem .5rem;}
.bebidas-table tbody tr:hover td{background:#f1f4f9}
.bebidas-table{--bs-table-bg:transparent;}
.bebidas-table td:last-child, .bebidas-table th:last-child{width:80px}

/* Onboarding panel removed; guidance handled via banner */

/* ===== Formularios (mobile-first) ===== */
.form-label{font-size:.9rem; color:#6c757d}
.form-control, .form-select{font-size:1rem; padding:.625rem .75rem; border-radius:12px}
.form-control::placeholder{color:#9aa3ad}
.btn{border-radius:12px}
.btn.w-100{padding:.75rem 1rem}

/* Filas dinámicas de bebidas */
.item-row{background:#fff; border-radius:14px; position:relative}
.item-row + .item-row{margin-top:.5rem}
.item-row .remove-item{min-height:44px}
.item-row select, .item-row input{background:#f8fafc}
.item-row .item-cantidad{text-align:center}
.item-row:focus-within{box-shadow:0 0 0 2px rgba(222,167,80,.2); border-color:#dea75055}

/* Sección bebidas wrapper */
#bebidasSection{background:transparent !important; border:0 !important; border-style:none !important; border-width:0 !important; border-color:transparent !important; border-radius:0 !important; outline:none !important; box-shadow:none !important; padding:0; margin-top:1.5rem}
#bebidasSection h6{font-size:.95rem; letter-spacing:.5px; font-weight:600}
#bebidasSection .form-text{margin-top:.75rem}

/* Entradas por día en metas: scroll horizontal en móviles */
.day-inputs{overflow-x:auto; -webkit-overflow-scrolling:touch; gap:.5rem}
.day-inputs > div{min-width:64px}
.weekdays{display:flex; align-items:center; gap:.5rem; flex-wrap:nowrap; overflow-x:auto; -webkit-overflow-scrolling:touch}
.weekdays::-webkit-scrollbar{display:none}

/* Ocultar scrollbars en day-inputs (webkit) */
.day-inputs::-webkit-scrollbar{display:none}

/* Utilidades */
.d-none-important{display:none !important}

/* =====================================================================
   ESTRUCTURA AMPLIADA · 5 secciones (Beber Menos)
   ===================================================================== */

/* Secciones genéricas */
.view-section{animation:fadeUp .25s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* Hero de sección */
.section-hero{border-radius:18px;padding:18px 18px 16px;margin-bottom:16px;color:#fff;position:relative;overflow:hidden}
.section-hero .hero-eyebrow{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;opacity:.92;display:flex;align-items:center;gap:6px}
.section-hero .hero-title{font-weight:800;font-size:1.5rem;margin:.25rem 0 .25rem}
.section-hero .hero-sub{font-size:.85rem;opacity:.95;margin:0;line-height:1.35}
.hero-portal{background:linear-gradient(135deg,#2f7fa6,#3aa0c4)}
.hero-registro{background:linear-gradient(135deg,#6a4fb0,#8a6fd0)}
.hero-programa{background:linear-gradient(135deg,#b8862e,#dea750)}
.hero-foro{background:linear-gradient(135deg,#1f9d7a,#37c39a)}

/* Tarjetas de contenido */
.content-card{border:1px solid #ece7da;border-radius:16px}
.content-card .card-body{padding:16px}
.block-title{display:flex;align-items:center;gap:8px;font-weight:700;font-size:.98rem;margin-bottom:10px}
.steps-list{padding-left:1.1rem}
.steps-list li{margin-bottom:.4rem}
.check-list{list-style:none;padding-left:0;margin-bottom:0}
.check-list li{position:relative;padding-left:1.5rem;margin-bottom:.35rem}
.check-list li::before{content:'\F26E';font-family:'bootstrap-icons';position:absolute;left:0;color:#2fb48c}
.resource-list{list-style:none;padding-left:0}
.resource-list li{padding:.4rem 0;border-bottom:1px solid #f0ece2}
.resource-list li:last-child{border-bottom:0}
.directory-item{padding:.5rem .75rem;background:#faf7f0;border-radius:10px}
.video-placeholder{background:#eef2f5;border:1px dashed #c8d2da}
.content-accordion .accordion-button{font-weight:600;font-size:.92rem}
.content-accordion .accordion-button:not(.collapsed){background:#fbf6ec;color:#b8862e}
.content-accordion .accordion-item{border-radius:12px;overflow:hidden;margin-bottom:8px;border:1px solid #ece7da}

/* Cuestionarios AUDIT */
.audit-form .group-label{display:flex;align-items:center;gap:8px;font-weight:800;color:#b8862e;text-transform:uppercase;font-size:.78rem;letter-spacing:.5px;margin:14px 4px 8px}
.audit-q .q-title{font-weight:600;font-size:.95rem;margin-bottom:10px;line-height:1.35}
.opt-group{display:flex;flex-direction:column;gap:8px}
.opt{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1.5px solid #e6e0d3;border-radius:12px;cursor:pointer;font-size:.9rem;transition:border-color .15s,background .15s}
.opt input{accent-color:#b8862e;width:18px;height:18px;flex:0 0 auto}
.opt:hover{border-color:#dea750}
.opt.selected{border-color:#b8862e;background:#fbf6ec;font-weight:600}

/* Resultado */
.result-card{border:1.5px solid #ece7da}
.result-badge{width:64px;height:64px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:1.7rem;color:#fff;background:#9aa3ad;margin-bottom:6px}
.result-badge.ok{background:#2fb48c}
.result-badge.warn{background:#dea750}
.result-badge.danger{background:#d9534f}
.result-score{font-size:.95rem;color:#6c757d}
.result-level{font-weight:800}

/* Progreso de registro (stepper) */
.reg-progress{display:flex;gap:6px;justify-content:space-between}
.reg-step{flex:1;text-align:center;font-weight:700;color:#9aa3ad;position:relative}
.reg-step{display:flex;flex-direction:column;align-items:center;gap:2px}
.reg-step::before{content:attr(data-x)}
.reg-step{font-size:.78rem}
.reg-step > span{font-weight:600;font-size:.68rem;color:#9aa3ad}
.reg-step{padding-top:30px}
.reg-step::after{content:'';position:absolute;top:0;width:26px;height:26px;border-radius:50%;background:#e9e4d8;color:#9aa3ad;display:flex;align-items:center;justify-content:center}
.reg-step{counter-increment:none}
.reg-step.active::after,.reg-step.done::after{background:#b8862e}
.reg-step.active,.reg-step.active > span{color:#b8862e}
/* number inside circle via content of first text node trick: use ::after with attr fallback */
.reg-step::after{content:attr(data-n)}

/* Consentimiento */
.consent-text p{margin-bottom:.6rem}

/* Grupo asignado */
.group-badge{width:72px;height:72px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:1.9rem;color:#fff;background:#9aa3ad}
.group-badge.normal{background:#b8862e}
.group-badge.orient{background:#1f9d7a}

/* Stepper de registro — versión limpia (anula reglas previas) */
.reg-progress{display:flex;gap:8px;justify-content:space-between;align-items:flex-start}
.reg-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:0;font-weight:800;font-size:0;color:transparent}
.reg-step::before,.reg-step::after{content:none !important}
.reg-step{position:static}
.reg-step{counter-reset:none}
.reg-step > span{font-size:.68rem;font-weight:600;color:#9aa3ad}
/* Número: estilizamos el nodo de texto haciendo el contenedor un círculo con el primer carácter */
.reg-step{}
.reg-num{display:flex}

/* Stepper final — con spans .reg-n / .reg-t */
.reg-step{font-size:1rem;color:inherit}
.reg-n{width:28px;height:28px;border-radius:50%;background:#e9e4d8;color:#9aa3ad;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem}
.reg-t{font-size:.68rem;font-weight:600;color:#9aa3ad}
.reg-step.active .reg-n,.reg-step.done .reg-n{background:#b8862e;color:#fff}
.reg-step.active .reg-t,.reg-step.done .reg-t{color:#b8862e}

/* Mini KPIs */
.mini-kpi{background:#faf7f0;border:1px solid #ece7da;border-radius:12px;padding:10px 6px;text-align:center;height:100%}
.mini-kpi-val{font-weight:800;font-size:1.1rem;color:#b8862e;line-height:1.1}
.mini-kpi-lbl{font-size:.66rem;color:#8a8577;margin-top:2px;font-weight:600}

/* Dashboard avance */
.program-progress{height:10px;border-radius:999px;background:#ece7da}
.program-progress .progress-bar{background:linear-gradient(90deg,#b8862e,#dea750)}
.week-dots{display:flex;gap:8px;justify-content:space-between}
.week-dot{flex:1;text-align:center;font-size:.75rem;font-weight:700;color:#9aa3ad;background:#ece7da;border-radius:8px;padding:4px 0}
.week-dot.done{background:#dea750;color:#fff}
.next-list{list-style:none;padding-left:0;margin-bottom:0}
.next-list li{display:flex;align-items:center;gap:10px;padding:.5rem 0;border-bottom:1px solid #f0ece2}
.next-list li:last-child{border-bottom:0}
.next-list li i{font-size:1.05rem}
.step-tile{display:block;text-decoration:none;background:#faf7f0;border:1px solid #ece7da;border-radius:14px;padding:14px;text-align:center;color:#5a534a;transition:transform .15s,box-shadow .15s}
.step-tile:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.06);color:#b8862e}
.step-tile .step-num{width:34px;height:34px;margin:0 auto 6px;border-radius:50%;background:#b8862e;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800}
.step-tile .step-name{font-weight:700;font-size:.85rem}

/* Balance pros/contras */
.balance-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.balance-head{font-weight:700;font-size:.82rem;display:flex;align-items:center;gap:6px;margin-bottom:6px}
.balance-head.pros{color:#2fb48c}
.balance-head.cons{color:#d9534f}

/* Objetivo (paso 2) */
.objective-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.objective-opt{cursor:pointer;display:block}
.objective-opt input{display:none}
.objective-card{border:1.5px solid #e6e0d3;border-radius:14px;padding:14px 10px;text-align:center;transition:border-color .15s,background .15s}
.objective-card i{font-size:1.6rem;color:#b8862e;display:block;margin-bottom:4px}
.objective-opt input:checked + .objective-card{border-color:#b8862e;background:#fbf6ec}

/* Hub Paso 3 */
.hub-grid{display:flex;flex-direction:column;gap:10px}
.hub-tile{display:flex;align-items:center;gap:12px;text-decoration:none;background:#fff;border:1px solid #ece7da;border-radius:14px;padding:12px 14px;color:#3a352e;transition:transform .15s,box-shadow .15s}
.hub-tile:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.06)}
.hub-ic{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex:0 0 auto}
.hub-name{font-weight:700;font-size:.92rem}

/* Chips situaciones */
.chip-group{display:flex;flex-wrap:wrap;gap:8px}
.chip{cursor:pointer}
.chip input{display:none}
.chip span{display:inline-block;padding:7px 14px;border:1.5px solid #e6e0d3;border-radius:999px;font-size:.82rem;transition:all .15s}
.chip.on span{background:#b8862e;border-color:#b8862e;color:#fff}

/* Logros */
.badges-row{display:flex;gap:10px;flex-wrap:wrap}
.achievement{flex:1;min-width:70px;text-align:center;font-size:.66rem;font-weight:600;color:#9aa3ad}
.achievement i{display:block;font-size:1.5rem;width:50px;height:50px;line-height:50px;margin:0 auto 4px;border-radius:50%;background:#ece7da;color:#bcb3a0}
.achievement.unlocked{color:#b8862e}
.achievement.unlocked i{background:#fbe9c6;color:#b8862e}

/* Evaluaciones de seguimiento */
.followups{list-style:none;padding-left:0;margin:0}
.followups li{display:flex;align-items:center;justify-content:space-between;padding:.55rem 0;border-bottom:1px solid #f0ece2}
.followups li:last-child{border-bottom:0}

/* Sesiones orientación */
.session-num{width:38px;height:38px;border-radius:50%;background:#1f9d7a;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;flex:0 0 auto}

/* ===== Foro ===== */
.foro-av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#1f9d7a,#37c39a);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;flex:0 0 auto}
.foro-post{cursor:default}
.foro-open{cursor:pointer}
.foro-post .fw-semibold.foro-open:hover{color:#1f9d7a}
.foro-meta{display:flex;flex-wrap:wrap;gap:4px;align-items:center}
.foro-comment{border:1px solid #eef2f0;border-radius:12px;background:#fbfdfc}

/* ===== Menú offcanvas ===== */
.app-menu{max-width:330px;width:86vw}
.menu-accordion .accordion-button{font-weight:700;font-size:.95rem;padding:14px 16px}
.menu-accordion .accordion-button:not(.collapsed){background:#fbf6ec;color:#b8862e}
.menu-accordion .accordion-button:focus{box-shadow:none}
.menu-accordion .accordion-body{padding:6px 10px 12px}
.menu-sec-ic{width:24px;height:24px;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:.78rem;color:#fff;margin-right:10px;flex:0 0 auto}
.sec-portal{background:#2f7fa6}
.sec-registro{background:#6a4fb0}
.sec-programa{background:#b8862e}
.sec-foro{background:#1f9d7a}
.sec-admin{background:#6c757d}
.menu-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;color:#4a443c;text-decoration:none;font-size:.88rem;transition:background .12s}
.menu-link:hover{background:#f5f0e6;color:#b8862e}
.menu-link.active{background:#fbe9c6;color:#b8862e;font-weight:700}
.menu-link i{font-size:1rem;width:18px;text-align:center}
.menu-subhead{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:#a59a85;padding:10px 12px 4px}
.menu-locked{background:#f7f5ef;border-radius:10px}

/* Botón de menú en header */
#btnMenu{line-height:1}
