*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--font);font-size:var(--text-md);background:var(--bg);color:var(--gray-900);line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh;min-height:100dvh}
img,svg{display:block}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
ul,ol{list-style:none}

:root {
  --blue:#2563EB;--blue-hover:#1D4ED8;--blue-active:#1E40AF;
  --blue-50:#EFF6FF;--blue-100:#DBEAFE;--blue-200:#BFDBFE;
  --green:#16A34A;--green-50:#F0FDF4;--green-100:#DCFCE7;
  --red:#DC2626;--red-50:#FEF2F2;--red-100:#FEE2E2;
  --amber:#D97706;--amber-50:#FFFBEB;--amber-100:#FEF3C7;
  --gray-0:#FFFFFF;--gray-50:#F9FAFB;--gray-100:#F3F4F6;
  --gray-200:#E5E7EB;--gray-300:#D1D5DB;--gray-400:#9CA3AF;
  --gray-500:#6B7280;--gray-600:#4B5563;--gray-700:#374151;
  --gray-800:#1F2937;--gray-900:#111827;
  --bg:#FFFFFF;--surface:#FFFFFF;--surface-2:#F9FAFB;
  --border:#E5E7EB;--border-strong:#D1D5DB;
  --font:'DM Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  --text-xs:12px;--text-sm:13px;--text-md:15px;--text-base:17px;
  --text-lg:20px;--text-xl:24px;--text-2xl:28px;--text-3xl:34px;
  --space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;
  --space-5:20px;--space-6:24px;--space-7:28px;--space-8:32px;
  --space-10:40px;--space-12:48px;--space-16:64px;
  --radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;
  --shadow-xs:0 1px 2px rgba(0,0,0,.05);
  --shadow-sm:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 12px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.04);
  --shadow-lg:0 8px 24px rgba(0,0,0,.08),0 2px 8px rgba(0,0,0,.04);
  --tap:48px;
  --ease:cubic-bezier(.4,0,.2,1);--ease-out:cubic-bezier(0,0,.2,1);--duration:200ms;
  --sidebar-w:260px;
}

/* ── Tipografia ── */
.page-title{font-size:var(--text-2xl);font-weight:700;color:var(--gray-900);letter-spacing:-.02em;line-height:1.2}
.section-title{font-size:var(--text-xs);font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:.08em;padding-bottom:var(--space-2)}
.text-secondary{color:var(--gray-500)}.text-muted{color:var(--gray-400)}
.text-blue{color:var(--blue)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-amber{color:var(--amber)}

/* ── Cards ── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}
.card-body{padding:var(--space-5)}
.card-header{padding:var(--space-5);border-bottom:1px solid var(--border)}
.card-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border);background:var(--surface-2)}
.card-interactive{cursor:pointer;transition:box-shadow var(--duration) var(--ease),transform var(--duration) var(--ease)}
.card-interactive:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.card-interactive:active{transform:translateY(0);box-shadow:var(--shadow-xs)}
@media(min-width:768px){.card-body{padding:var(--space-6)}.card-header{padding:var(--space-6)}}

/* ── Forms ── */
.field{margin-bottom:var(--space-5)}
.field-label{display:flex;align-items:baseline;justify-content:space-between;font-size:var(--text-sm);font-weight:600;color:var(--gray-700);margin-bottom:var(--space-2)}
.field-label-hint{font-size:var(--text-xs);font-weight:400;color:var(--gray-400)}
.field-wrap{position:relative}
.field-input{width:100%;height:var(--tap);padding:0 var(--space-4);border:1.5px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--gray-900);background:var(--surface);transition:border-color var(--duration) var(--ease),box-shadow var(--duration) var(--ease);-webkit-appearance:none;appearance:none;outline:none}
.field-input::placeholder{color:var(--gray-400)}
.field-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.15)}
.field-input.has-icon-right{padding-right:52px}
.field-input.has-icon-left{padding-left:52px}
.field-input.invalid{border-color:var(--red);box-shadow:0 0 0 3px rgba(220,38,38,.1)}
.field-icon{position:absolute;top:0;height:var(--tap);width:48px;display:flex;align-items:center;justify-content:center;color:var(--gray-400)}
.field-icon.left{left:0;pointer-events:none}
.field-icon.right{right:0;pointer-events:auto;cursor:pointer;border:none;background:transparent;border-radius:0 var(--radius-md) var(--radius-md) 0;transition:color var(--duration)}
.field-icon.right:hover{color:var(--gray-600)}
.field-hint{font-size:var(--text-xs);color:var(--gray-400);margin-top:var(--space-1)}
.field-error{font-size:var(--text-xs);color:var(--red);margin-top:var(--space-1)}
.strength-bar{height:3px;background:var(--border);border-radius:2px;margin-top:var(--space-2);overflow:hidden}
.strength-fill{height:100%;border-radius:2px;transition:width .35s var(--ease),background .35s var(--ease);width:0}
.strength-hint{font-size:var(--text-xs);color:var(--gray-400);margin-top:var(--space-1)}

/* ── Botões ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:var(--tap);padding:0 var(--space-5);border:none;border-radius:var(--radius-md);font-size:var(--text-md);font-weight:600;cursor:pointer;text-decoration:none;transition:background var(--duration) var(--ease),box-shadow var(--duration) var(--ease),transform var(--duration) var(--ease);-webkit-tap-highlight-color:transparent;white-space:nowrap;user-select:none}
.btn-block{width:100%}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-hover);box-shadow:var(--shadow-sm)}
.btn-primary:active{background:var(--blue-active);transform:scale(.98)}
.btn-secondary{background:var(--surface);color:var(--gray-700);border:1.5px solid var(--border)}
.btn-secondary:hover{background:var(--surface-2);border-color:var(--border-strong)}
.btn-secondary:active{transform:scale(.98)}
.btn-ghost{background:transparent;color:var(--blue);padding:0 var(--space-2)}
.btn-ghost:hover{background:var(--blue-50)}
.btn-danger{background:var(--red);color:#fff}
.btn-danger:hover{background:#B91C1C}
.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}
.btn-sm{height:36px;padding:0 var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-sm)}
.btn-lg{height:54px;padding:0 var(--space-8);font-size:var(--text-lg);border-radius:var(--radius-lg)}
.btn-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:pw3-spin .65s linear infinite;flex-shrink:0;display:none}
.btn.loading .btn-spinner{display:block}
.btn.loading .btn-label{display:none}
@keyframes pw3-spin{to{transform:rotate(360deg)}}

/* ── Alerts ── */
.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);line-height:1.55;margin-bottom:var(--space-5)}
.alert svg{flex-shrink:0;margin-top:1px}
.alert-error{background:var(--red-50);border:1px solid var(--red-100);color:#991B1B}
.alert-success{background:var(--green-50);border:1px solid var(--green-100);color:#166534}
.alert-info{background:var(--blue-50);border:1px solid var(--blue-100);color:#1E40AF}
.alert-warning{background:var(--amber-50);border:1px solid var(--amber-100);color:#92400E}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;gap:var(--space-1);height:22px;padding:0 var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;white-space:nowrap}
.badge-blue{background:var(--blue-50);color:var(--blue)}
.badge-green{background:var(--green-50);color:var(--green)}
.badge-red{background:var(--red-50);color:var(--red)}
.badge-amber{background:var(--amber-50);color:var(--amber)}
.badge-gray{background:var(--gray-100);color:var(--gray-600)}

/* ── Sidebar desktop ── */
.sidebar{display:none}
@media(min-width:1024px){
  .sidebar{display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);padding:var(--space-6);z-index:100;overflow-y:auto}
  .sidebar-logo{margin-bottom:var(--space-8)}
  .sidebar-logo img{max-height:32px;max-width:130px;width:auto;height:auto;object-fit:contain}
  .sidebar-nav{display:flex;flex-direction:column;gap:2px;flex:1}
  .sidebar-item{display:flex;align-items:center;gap:var(--space-3);height:44px;padding:0 var(--space-3);border-radius:var(--radius-md);color:var(--gray-600);font-size:var(--text-md);font-weight:500;text-decoration:none;transition:background var(--duration),color var(--duration);cursor:pointer;border:none;background:transparent;font-family:var(--font);width:100%;text-align:left}
  .sidebar-item:hover{background:var(--gray-100);color:var(--gray-900)}
  .sidebar-item.active{background:var(--blue-50);color:var(--blue);font-weight:600}
  .sidebar-footer{padding-top:var(--space-6);border-top:1px solid var(--border)}
}

/* ── Top header mobile ── */
.top-header{position:sticky;top:0;z-index:90;background:rgba(255,255,255,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);height:calc(56px + env(safe-area-inset-top));padding-top:env(safe-area-inset-top);display:flex;align-items:center;padding-left:var(--space-4);padding-right:var(--space-4);gap:var(--space-3)}
@media(min-width:1024px){.top-header{display:none}}
.top-header-logo img{max-height:28px;max-width:110px;width:auto;height:auto;object-fit:contain}
.top-header-title{font-size:var(--text-base);font-weight:600;color:var(--gray-900);flex:1}
.top-header-actions{display:flex;align-items:center;gap:var(--space-1)}
.icon-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:var(--radius-md);color:var(--gray-600);cursor:pointer;transition:background var(--duration),color var(--duration);-webkit-tap-highlight-color:transparent;text-decoration:none}
.icon-btn:hover{background:var(--gray-100);color:var(--gray-900)}

/* ── App content ──
   Mobile: coluna centralizada
   Desktop: ocupa TUDO após a sidebar, sem max-width global
   Cada view controla seu próprio layout interno
── */
.app-content{
  padding:var(--space-5) var(--space-4);
  padding-bottom:calc(56px + env(safe-area-inset-bottom) + var(--space-5));
}
@media(min-width:768px){
  .app-content{padding:var(--space-8) var(--space-6);padding-bottom:calc(56px + env(safe-area-inset-bottom) + var(--space-8))}
}
@media(min-width:1024px){
  .app-content{
    margin-left:var(--sidebar-w);
    padding-top:calc(52px + var(--space-4));
    padding-left:var(--space-10);
    padding-right:var(--space-10);
    padding-bottom:var(--space-10);
    min-height:100vh;
  }
}

/* Helpers de largura para usar dentro das views */
.content-full   { width:100% }
.content-wide   { width:100%; max-width:1200px }
.content-medium { width:100%; max-width:860px;  margin-left:auto; margin-right:auto }
.content-narrow { width:100%; max-width:640px;  margin-left:auto; margin-right:auto }

/* ── Bottom nav mobile ── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:center;padding-bottom:env(safe-area-inset-bottom);height:calc(56px + env(safe-area-inset-bottom))}
.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;flex:1;height:56px;color:var(--gray-400);font-size:10px;font-weight:600;letter-spacing:.02em;transition:color var(--duration) var(--ease);-webkit-tap-highlight-color:transparent;cursor:pointer;border:none;background:transparent;font-family:var(--font);text-decoration:none}
.bottom-nav-item.active{color:var(--blue)}
.bottom-nav-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:9px;transition:background var(--duration) var(--ease)}
.bottom-nav-item.active .bottom-nav-icon{background:var(--blue-50)}
@media(min-width:1024px){.bottom-nav{display:none}}

/* ── Auth ── */
.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:var(--space-6) var(--space-4);padding-top:calc(var(--space-6) + env(safe-area-inset-top));padding-bottom:calc(var(--space-6) + env(safe-area-inset-bottom));background:var(--gray-50)}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:420px;animation:pw3-card-enter .3s var(--ease-out) both}
@keyframes pw3-card-enter{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.auth-header{padding:var(--space-8) var(--space-8) var(--space-6);text-align:center}
.auth-logo{display:flex;justify-content:center;margin-bottom:var(--space-6)}
.auth-logo img{max-width:160px;max-height:52px;width:auto;height:auto;object-fit:contain}
.auth-title{font-size:var(--text-xl);font-weight:700;color:var(--gray-900);letter-spacing:-.02em;margin-bottom:var(--space-1)}
.auth-subtitle{font-size:var(--text-md);color:var(--gray-500)}
.auth-body{padding:var(--space-6) var(--space-8) var(--space-8)}
.auth-footer-link{text-align:center;font-size:var(--text-sm);color:var(--gray-500);margin-top:var(--space-5)}
.auth-link{color:var(--blue);font-weight:500}
.auth-link:hover{text-decoration:underline}
@media(min-width:480px){
  .auth-header{padding:var(--space-8) var(--space-10) var(--space-6)}
  .auth-body{padding:var(--space-6) var(--space-10) var(--space-10)}
  .auth-logo img{max-width:180px;max-height:60px}
}

/* ── Saudação animada ── */
.greeting-wrap{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6)}
.greeting-icon{width:56px;height:56px;position:relative;flex-shrink:0}

/* Sol */
.ico-sun .sun-core{fill:#F59E0B}
.ico-sun .sun-ray{stroke:#F59E0B;stroke-width:2;stroke-linecap:round}
.ico-sun{animation:sun-pulse 3s ease-in-out infinite}
@keyframes sun-pulse{0%,100%{transform:scale(1) rotate(0deg)}50%{transform:scale(1.08) rotate(20deg)}}
.sun-ray{transform-origin:28px 28px;animation:ray-blink 2s ease-in-out infinite}
.sun-ray:nth-child(2){animation-delay:.15s}
.sun-ray:nth-child(3){animation-delay:.3s}
.sun-ray:nth-child(4){animation-delay:.45s}
.sun-ray:nth-child(5){animation-delay:.6s}
.sun-ray:nth-child(6){animation-delay:.75s}
.sun-ray:nth-child(7){animation-delay:.9s}
.sun-ray:nth-child(8){animation-delay:1.05s}
@keyframes ray-blink{0%,100%{opacity:1}50%{opacity:.4}}

/* Pôr do sol com nuvem */
.ico-sunset .sun-core{fill:#F97316}
.ico-sunset .sun-ray{stroke:#F97316;stroke-width:2;stroke-linecap:round}
.ico-sunset{animation:sun-pulse 4s ease-in-out infinite}
.ico-sunset .cloud{fill:#E5E7EB;animation:cloud-drift 4s ease-in-out infinite}
@keyframes cloud-drift{0%,100%{transform:translateX(0)}50%{transform:translateX(3px)}}

/* Lua com estrelas */
.ico-moon .moon{fill:#6366F1}
.ico-moon .star{fill:#A5B4FC;animation:star-twinkle 2s ease-in-out infinite}
.ico-moon .star:nth-child(2){animation-delay:.4s}
.ico-moon .star:nth-child(3){animation-delay:.8s}
.ico-moon{animation:moon-sway 5s ease-in-out infinite}
@keyframes moon-sway{0%,100%{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}
@keyframes star-twinkle{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.2;transform:scale(.6)}}

.greeting-text{}
.greeting-period{font-size:var(--text-xs);font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px}
.greeting-name{font-size:var(--text-2xl);font-weight:700;color:var(--gray-900);letter-spacing:-.02em;line-height:1.2}
.greeting-name span{color:var(--blue)}

/* ── Utilitários ── */
.hidden{display:none!important}
.w-full{width:100%}
.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}
.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}
.text-center{text-align:center}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}
.flex-1{flex:1}
.divider{height:1px;background:var(--border);margin:var(--space-5) 0}
.fade-in{animation:pw3-fade-in .25s var(--ease-out) both}
@keyframes pw3-fade-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
/* Botão de ação no page-header */
.btn-action{padding:10px 18px;background:var(--blue,#2563EB);color:#fff;border:none;border-radius:var(--radius-md,12px);font-size:13px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;text-decoration:none;min-height:44px}
.btn-action:disabled{opacity:.6;cursor:not-allowed}
.btn-action--outline{background:transparent;color:var(--blue,#2563EB);border:1.5px solid var(--blue,#2563EB)}
