/* Clean premium — dark UI */
:root{
  --bg:#0b1220;
  --panel:#0f172a;
  --card:#111b33;
  --card2:#0f1a2f;
  --border:#1f2a44;
  --text:#e5e7eb;
  --muted:#9ca3af;
  --primary:#38bdf8;
  --primary2:#60a5fa;
  --good:#22c55e;
  --bad:#ef4444;
  --shadow: 0 14px 40px rgba(0,0,0,.35);
  --radius: 18px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  background: radial-gradient(900px 600px at 20% 0%, rgba(56,189,248,.18), transparent 60%),
              radial-gradient(900px 600px at 80% 0%, rgba(96,165,250,.14), transparent 55%),
              var(--bg);
  color:var(--text);
}
#app{height:100%}
.topbar{
  position: sticky; top: 0; z-index: 10;
  display:flex; align-items:center; justify-content:space-between;
  padding: 14px 16px;
  background: linear-gradient(180deg, rgba(11,18,32,.95), rgba(11,18,32,.72));
  border-bottom: 1px solid rgba(31,42,68,.75);
  backdrop-filter: blur(10px);
}
.brand{display:flex; gap:12px; align-items:center}
.logo{
  width:42px;height:42px;border-radius:14px;
  display:grid;place-items:center;
  font-weight:900;
  background: linear-gradient(135deg, rgba(56,189,248,.95), rgba(96,165,250,.65));
  box-shadow: 0 10px 24px rgba(56,189,248,.18);
  color:#06111f;
}
.brand-title{font-weight:800; letter-spacing:.2px}
.brand-sub{font-size:12px;color:var(--muted); margin-top:2px}
.topbar-actions{display:flex; align-items:center; gap:10px}
.badge{
  padding: 8px 10px;
  border-radius: 999px;
  font-weight:700;
  background: rgba(17,27,51,.7);
  border:1px solid rgba(31,42,68,.85);
  color: var(--text);
}
.badge.pro{
  background: rgba(34,197,94,.12);
  border-color: rgba(34,197,94,.35);
}
.btn{
  border: 1px solid rgba(31,42,68,.85);
  background: rgba(17,27,51,.65);
  color: var(--text);
  padding: 10px 12px;
  border-radius: 14px;
  cursor:pointer;
  font-weight:700;
  transition: transform .06s ease, background .2s ease, border-color .2s ease;
}
.btn:hover{background: rgba(17,27,51,.85)}
.btn:active{transform: translateY(1px)}
.btn.primary{
  border-color: rgba(56,189,248,.55);
  background: linear-gradient(135deg, rgba(56,189,248,.22), rgba(96,165,250,.16));
}
.btn.ghost{background: transparent}
.layout{display:grid; grid-template-columns: 260px 1fr; height: calc(100% - 72px)}
.sidebar{
  padding: 14px;
  border-right: 1px solid rgba(31,42,68,.7);
  background: linear-gradient(180deg, rgba(15,23,42,.85), rgba(15,23,42,.55));
  position: relative;
}
.nav{
  width:100%;
  display:flex;
  align-items:center;
  gap:10px;
  padding: 10px 12px;
  border-radius: 14px;
  margin-bottom: 8px;
  cursor:pointer;
  background: transparent;
  color: var(--text);
  border: 1px solid transparent;
  font-weight: 750;
  letter-spacing: .15px;
}
.nav:hover{background: rgba(17,27,51,.5); border-color: rgba(31,42,68,.7)}
.nav.active{background: rgba(17,27,51,.8); border-color: rgba(56,189,248,.28)}
.nav-ico{width:20px; text-align:center}
.pill{
  margin-left:auto;
  font-size:11px;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid rgba(56,189,248,.25);
  color: rgba(56,189,248,.95);
  background: rgba(56,189,248,.08);
}
.sidebar-footer{display:none}
.tiny{font-size:12px}
.muted{color:var(--muted)}
.content{padding: 18px 18px 26px 18px; overflow:auto}
.card{
  background: rgba(17,27,51,.72);
  border: 1px solid rgba(31,42,68,.75);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.h1{font-size:22px; font-weight:900; letter-spacing:.2px; margin:0 0 8px 0}
.h2{font-size:14px; color: var(--muted); margin:0 0 14px 0}
.hr{height:1px; background: rgba(31,42,68,.75); margin: 14px 0}
.row{display:flex; gap:10px; align-items:center}
.input, select.input, textarea.input{
  width:100%;
  background: rgba(15,26,47,.75);
  border: 1px solid rgba(31,42,68,.9);
  color: var(--text);
  padding: 10px 12px;
  border-radius: 14px;
  outline: none;
}
.input:focus, select.input:focus, textarea.input:focus{
  border-color: rgba(56,189,248,.55);
  box-shadow: 0 0 0 3px rgba(56,189,248,.15);
}
.list{padding:12px}
.item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding: 10px 10px;
  border-radius: 14px;
  border: 1px solid rgba(31,42,68,.7);
  background: rgba(15,26,47,.52);
  margin-bottom: 10px;
}
.item:hover{background: rgba(15,26,47,.7)}
.kbd{font-size:12px; padding:4px 8px; border-radius:10px; border:1px solid rgba(31,42,68,.8); color:var(--muted)}
.right{display:flex; gap:8px; align-items:center}
.tag{
  font-size:12px;
  padding:4px 8px;
  border-radius: 999px;
  border:1px solid rgba(31,42,68,.85);
  color: var(--muted);
}
.tag.good{border-color: rgba(34,197,94,.4); background: rgba(34,197,94,.1); color: rgba(180,255,210,.92)}
.tag.bad{border-color: rgba(239,68,68,.4); background: rgba(239,68,68,.1); color: rgba(255,190,190,.95)}
.icon-btn{
  border: 1px solid rgba(31,42,68,.85);
  background: rgba(17,27,51,.55);
  color: var(--text);
  width: 38px;
  height: 38px;
  border-radius: 14px;
  cursor:pointer;
}
.icon-btn:hover{background: rgba(17,27,51,.85)}
.modal{
  position: fixed; inset: 0;
  display:grid; place-items:center;
  z-index: 30;
}
.modal.hidden{display:none}
.modal-backdrop{
  z-index: 0;
  position:absolute; inset:0;
  background: rgba(0,0,0,.58);
  backdrop-filter: blur(6px);
}
.modal-card{
  z-index: 1;
  position:relative;
  width: min(860px, 92vw);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(17,27,51,.95), rgba(15,23,42,.92));
  border: 1px solid rgba(31,42,68,.85);
  box-shadow: 0 22px 70px rgba(0,0,0,.5);
  padding: 16px;
}
.modal-head{display:flex; align-items:flex-start; justify-content:space-between; gap:12px}
.modal-title{font-size:18px; font-weight:900}
.modal-sub{font-size:12px; color: var(--muted); margin-top: 3px}
.pricing{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
  margin-top: 12px;
}
.price-card{
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(31,42,68,.78);
  background: rgba(15,26,47,.55);
}
.price-card.featured{
  border-color: rgba(56,189,248,.45);
  background: radial-gradient(400px 200px at 50% 0%, rgba(56,189,248,.16), transparent 55%),
              rgba(15,26,47,.58);
}
.price-title{font-weight:900}
.price-value{font-size:26px; font-weight:950; margin:6px 0}
.ul{padding-left: 18px; margin: 10px 0 0 0; color: var(--muted); font-size: 13px}
.ul li{margin:6px 0}
.modal-actions{display:flex; gap:10px; justify-content:flex-end; margin-top: 14px}
.keybox{margin-top: 12px}
.label{display:block; margin: 8px 0; font-weight:800; font-size: 12px; color: var(--muted)}
.form{margin-top: 12px}
.chip{
  border: 1px solid rgba(31,42,68,.85);
  background: rgba(15,26,47,.55);
  color: var(--text);
  padding: 10px 12px;
  border-radius: 999px;
  cursor:pointer;
  font-weight: 800;
}
.chip:hover{background: rgba(15,26,47,.78)}
.banner{
  border:1px solid rgba(56,189,248,.35);
  background: rgba(56,189,248,.08);
  padding:10px 12px;
  border-radius: 14px;
  margin: 10px 0;
}


/* ===== Dashboard / Weekly calendar ===== */
.grid2{display:grid;grid-template-columns:1.2fr .8fr;gap:14px;}
@media (max-width:980px){.grid2{grid-template-columns:1fr}}
.week{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;}
.day{border:1px solid rgba(31,42,68,.75);background:rgba(15,26,47,.48);border-radius:16px;padding:10px;min-height:170px;}
.day-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.day-title{font-weight:950;font-size:12px}
.day-sub{font-size:11px;color:var(--muted)}
.block{border:1px solid rgba(56,189,248,.25);background:rgba(56,189,248,.08);border-radius:14px;padding:8px;margin-bottom:8px;cursor:pointer;}
.block-title{font-weight:900;font-size:12px}
.block-sub{font-size:11px;color:var(--muted);margin-top:3px}
.progress{height:10px;background:rgba(31,42,68,.7);border-radius:999px;overflow:hidden;}
.progress>div{height:100%;width:0%;background:rgba(34,197,94,.55);border-radius:999px;}
.kpi{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.kpi .k{border:1px solid rgba(31,42,68,.75);background:rgba(15,26,47,.48);border-radius:16px;padding:10px;}
.k-title{font-size:12px;color:var(--muted);font-weight:800}
.k-value{font-size:20px;font-weight:950;margin-top:6px}
.notice{border:1px dashed rgba(56,189,248,.35);background:rgba(56,189,248,.06);border-radius:16px;padding:10px;color:rgba(229,231,235,.85);font-size:12px;}
.badge-mini{font-size:11px;padding:4px 8px;border-radius:999px;border:1px solid rgba(31,42,68,.85);color:var(--muted);}

/* ===== Focus mode ===== */
.focus-wrap{padding:14px;border-radius:22px;border:1px solid rgba(31,42,68,.75);
  background:radial-gradient(600px 280px at 50% 0%, rgba(56,189,248,.16), transparent 60%),rgba(15,23,42,.62);
  box-shadow:0 22px 70px rgba(0,0,0,.5);}
.focus-big{font-size:56px;font-weight:950;letter-spacing:.6px;text-align:center;margin:10px 0;}
.center{display:grid;place-items:center}
.small-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}


/* ===== UI hotfixes (layout/clip) ===== */

html, body { min-height: 100%; }
body {
  line-height: 1.35;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
#app {
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto 1fr;
}
.topbar {
  min-height: 72px;
  gap: 10px;
}
.brand { min-width: 0; }
.brand-title, .brand-sub {
  line-height: 1.2;
}
.layout {
  height: auto;
  min-height: 0;
  grid-template-columns: 280px minmax(0, 1fr);
}
.sidebar {
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: auto;
  padding-bottom: 12px;
}
.sidebar-footer {
  position: static;
  margin-top: auto;
  padding-top: 12px;
  background: linear-gradient(180deg, rgba(15,23,42,0), rgba(15,23,42,.75) 30%);
}
.content {
  min-width: 0;
  min-height: 0;
  overflow: auto;
}
.h1, .h2, .modal-title, .modal-sub, .label, .tiny { line-height: 1.3; }

.nav {
  min-height: 44px;
  line-height: 1.2;
  text-align: left;
  white-space: normal;
}
.nav-ico {
  flex: 0 0 20px;
  line-height: 1;
}
.pill { line-height: 1.1; }

.btn,
.chip,
.input,
select.input,
textarea.input,
.badge,
.icon-btn {
  line-height: 1.25;
}
.btn,
.chip,
.icon-btn { min-height: 40px; }
.input,
select.input { min-height: 42px; }
textarea.input {
  min-height: 120px;
  resize: vertical;
}

.item { align-items: flex-start; }
.item > div:first-child { min-width: 0; }
.item > div:first-child > div:first-child {
  line-height: 1.25;
  overflow-wrap: anywhere;
}
.right {
  flex-wrap: wrap;
  justify-content: flex-end;
}
.kbd, .tag { line-height: 1.15; }

.modal-card {
  max-height: min(92vh, 820px);
  overflow: auto;
}
.modal-actions {
  flex-wrap: wrap;
}

@media (max-width: 980px) {
  .layout { grid-template-columns: 1fr; }
  .sidebar {
    border-right: none;
    border-bottom: 1px solid rgba(31,42,68,.7);
    max-height: 42vh;
  }
  .sidebar-footer {
    margin-top: 8px;
    background: transparent;
  }
  .week { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .pricing { grid-template-columns: 1fr; }
}

@media (max-width: 700px) {
  .topbar {
    flex-wrap: wrap;
    align-items: flex-start;
  }
  .topbar-actions {
    width: 100%;
    justify-content: space-between;
  }
  .week { grid-template-columns: 1fr; }
  .grid2 { grid-template-columns: 1fr; }
  .focus-big { font-size: 42px; }
}


/* ===== Today view / Heatmap ===== */
.hero-today{display:grid;grid-template-columns:1.2fr .8fr;gap:10px;}
.hero-left,.hero-right{border:1px solid rgba(31,42,68,.75);background:rgba(15,26,47,.48);border-radius:16px;padding:12px;}
.hero-value{font-size:34px;font-weight:950;line-height:1;margin-top:6px;}
.heatmap{display:grid;grid-template-columns:repeat(14,1fr);gap:6px;}
.heat{height:14px;border-radius:4px;border:1px solid rgba(31,42,68,.75);background:rgba(15,26,47,.4);}
.heat.lv1{background:rgba(34,197,94,.20);border-color:rgba(34,197,94,.25);}
.heat.lv2{background:rgba(34,197,94,.35);border-color:rgba(34,197,94,.40);}
.heat.lv3{background:rgba(34,197,94,.55);border-color:rgba(34,197,94,.55);}

@media (max-width: 900px){.hero-today{grid-template-columns:1fr}}


.tag.warn{background:rgba(250,204,21,.14);border-color:rgba(250,204,21,.35);color:#fde68a;}
.item-overdue{border:1px solid rgba(239,68,68,.28);border-radius:14px;padding:10px;}
#taskTimerInfo{display:flex;align-items:center;}

/* ===== Calendar monthly ===== */
.cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;}
.cal-head{margin-bottom:8px;}
.cal-h{font-size:12px;color:var(--muted);font-weight:800;text-align:center;}
.cal-cell{min-height:82px;border:1px solid rgba(31,42,68,.75);background:rgba(15,26,47,.45);border-radius:14px;padding:8px;text-align:left;color:var(--text);}
.cal-cell.empty{opacity:.25;pointer-events:none;}
.cal-cell.today{outline:1px solid rgba(56,189,248,.5);}
.cal-cell.selected{border-color:rgba(99,102,241,.65);box-shadow:0 0 0 1px rgba(99,102,241,.25) inset;}
.cal-num{font-weight:900;font-size:14px;margin-bottom:4px;}
.cal-meta{font-size:11px;color:var(--muted);line-height:1.25;}


/* v5 extras */
body[data-theme="luxo"]{
  --bg:#050608; --card:#111114; --card2:#17181d; --line:#2a2b33; --text:#f5f1e8; --muted:#b8ad95; --brand1:#f6d38a; --brand2:#c58b2c;
}
body[data-theme="luxo"] .topbar, body[data-theme="luxo"] .sidebar{ background:linear-gradient(180deg, rgba(14,14,18,.95), rgba(10,10,12,.95)); }
body[data-theme="luxo"] .btn.primary{ background:linear-gradient(90deg,var(--brand2),var(--brand1)); color:#1a1205; border-color:rgba(246,211,138,.5); }
body[data-theme="luxo"] .badge.pro{ background:rgba(246,211,138,.12); color:var(--brand1); border-color:rgba(246,211,138,.35); }
.alerts-box{display:grid;gap:6px}
.alert-row{padding:8px 10px;border-radius:10px;border:1px solid rgba(31,42,68,.65);background:rgba(15,26,47,.35);font-size:12px}
.alert-row.is-late{border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.08)}
.alert-row.is-today{border-color:rgba(250,204,21,.35);background:rgba(250,204,21,.08)}
.alert-row.is-tomorrow{border-color:rgba(56,189,248,.35);background:rgba(56,189,248,.08)}


/* ===== Settings modal (redesign) ===== */
.settings-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}
.settings-panel{
  border: 1px solid rgba(31,42,68,.8);
  background: rgba(15,26,47,.52);
  border-radius: 18px;
  padding: 12px;
}
.settings-panel-title{
  font-weight: 950;
  font-size: 14px;
}
.settings-panel-sub{
  color: var(--muted);
  font-size: 12px;
  margin-top: 4px;
  margin-bottom: 8px;
}
.settings-theme-row{
  flex-wrap: wrap;
  gap:8px;
}
.settings-note{
  margin-top: 10px;
  border: 1px dashed rgba(56,189,248,.3);
  background: rgba(56,189,248,.06);
  border-radius: 12px;
  padding: 10px;
  font-size: 12px;
  color: var(--text);
}
.settings-mini-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:8px;
}
.mini-card{
  border: 1px solid rgba(31,42,68,.75);
  border-radius: 12px;
  background: rgba(10,18,34,.35);
  padding: 10px;
}
.mini-title{
  font-weight: 900;
  font-size: 12px;
  margin-bottom: 4px;
}
@media (max-width: 860px){
  .settings-grid{ grid-template-columns: 1fr; }
}


/* ===== Mobile-first polish v2.3 ===== */
img{max-width:100%;height:auto}
@media (max-width: 900px){
  .topbar{padding:12px;align-items:flex-start}
  .brand{width:100%}
  .brand-title{font-size:18px}
  .brand-sub{font-size:11px}
  .topbar-actions{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .topbar-actions .btn,
  .topbar-actions .badge{width:100%;justify-content:center}
  .topbar-actions #planBadge{grid-column:1/-1}

  .layout{grid-template-columns:1fr;gap:0}
  .sidebar{
    position:sticky;
    top:72px;
    z-index:8;
    display:flex;
    flex-direction:row;
    flex-wrap:nowrap;
    gap:8px;
    padding:10px 12px;
    overflow-x:auto;
    overflow-y:hidden;
    border-bottom:1px solid rgba(31,42,68,.7);
    background:rgba(11,18,32,.92);
    backdrop-filter:blur(10px);
    scrollbar-width:thin;
    max-height:none;
  }
  .sidebar::-webkit-scrollbar{height:8px}
  .sidebar::-webkit-scrollbar-thumb{background:rgba(56,189,248,.25);border-radius:999px}
  .nav{flex:0 0 auto;margin:0;white-space:nowrap;min-height:42px;padding:10px 12px}
  .nav .pill{margin-left:8px}
  .sidebar-footer{display:none}
  .content{padding:14px 12px 22px}
  .card,.modal-card,.day,.price-card,.settings-panel{border-radius:16px}
  .row{flex-wrap:wrap}
  .row > *{min-width:0}
  .item{flex-direction:column;align-items:stretch}
  .right{justify-content:flex-start}
  .modal{padding:10px}
  .modal-card{width:min(100%, 100vw);max-height:calc(100vh - 20px);padding:14px}
  .modal-head{align-items:flex-start}
  .modal-actions{justify-content:stretch}
  .modal-actions .btn{flex:1 1 100%}
  .pricing{grid-template-columns:1fr}
  .kpi{grid-template-columns:1fr}
  .hero-today{grid-template-columns:1fr}
  .heatmap{grid-template-columns:repeat(7,1fr)}
  .cal-grid{gap:6px}
  .cal-cell{min-height:72px;padding:6px}
  .focus-big{font-size:36px}
}

@media (max-width: 640px){
  body{font-size:15px}
  .topbar{padding:10px}
  .logo{width:38px;height:38px;border-radius:12px}
  .topbar-actions{grid-template-columns:1fr}
  .topbar-actions #planBadge{grid-column:auto}
  .h1{font-size:20px}
  .h2{font-size:13px}
  .btn,.chip,.icon-btn{min-height:44px;padding:11px 12px}
  .input,select.input{min-height:44px}
  textarea.input{min-height:110px}
  .week{grid-template-columns:1fr}
  .day{min-height:140px}
  .cal-grid{grid-template-columns:repeat(7, minmax(38px,1fr));font-size:12px}
  .cal-num{font-size:12px}
  .cal-meta{font-size:10px}
  .focus-wrap{padding:12px}
  .focus-big{font-size:32px}
  .settings-mini-grid{grid-template-columns:1fr}
}

/* ===== v2.4 mobile drawer + pro lock ===== */
.mobile-menu-btn{display:none}
.mobile-nav-backdrop{display:none}
.nav.is-locked{border-color:rgba(250,204,21,.22);background:rgba(250,204,21,.06)}
.nav.is-locked .pill{border-color:rgba(250,204,21,.28);background:rgba(250,204,21,.10);color:#fde68a}
.nav.is-locked::after{content:"🔒";margin-left:8px;font-size:12px;opacity:.9}

@media (max-width: 900px){
  .mobile-menu-btn{display:inline-flex}
  .layout{position:relative}
  .mobile-nav-backdrop{
    position:fixed;
    inset:0;
    background:rgba(2,6,23,.55);
    backdrop-filter:blur(4px);
    opacity:0;
    pointer-events:none;
    transition:opacity .22s ease;
    z-index:24;
    display:block;
  }
  body.mobile-nav-open .mobile-nav-backdrop{
    opacity:1;
    pointer-events:auto;
  }
  .sidebar{
    position:fixed;
    top:0;
    left:0;
    bottom:0;
    width:min(86vw,360px);
    max-width:360px;
    z-index:26;
    padding:18px 14px 20px;
    overflow-y:auto;
    overflow-x:hidden;
    border-right:1px solid rgba(31,42,68,.78);
    border-bottom:none;
    background:linear-gradient(180deg, rgba(8,15,29,.98), rgba(15,23,42,.98));
    box-shadow:0 28px 90px rgba(0,0,0,.55);
    transform:translateX(-108%);
    transition:transform .24s ease;
    display:flex;
    flex-direction:column;
    flex-wrap:nowrap;
    gap:10px;
    top:0;
  }
  body.mobile-nav-open .sidebar{transform:translateX(0)}
  .sidebar{height:100dvh;max-height:100dvh;padding-bottom:calc(110px + env(safe-area-inset-bottom));-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scroll-padding-bottom:120px;}
  .sidebar::before{
    content:"Menu do app";
    display:block;
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:.08em;
    color:var(--muted);
    font-weight:900;
    margin:2px 4px 6px;
  }
  .nav{
    width:100%;
    margin:0;
    white-space:normal;
    min-height:48px;
    justify-content:flex-start;
    padding:12px 14px;
  }
  .nav .pill{margin-left:auto}
  .sidebar-footer{display:none !important;position:static;left:auto;right:auto;bottom:auto;margin-top:0;padding-top:0;border-top:0;background:none}
  .content{
    padding:12px 10px 24px;
  }
  .list{padding:10px}
  .item{padding:12px}
  .item .right{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%}
  .item .right .btn,
  .item .right .icon-btn,
  .item .right .tag,
  .item .right .kbd{width:100%;justify-content:center;text-align:center}
  .card .row,
  .form .row,
  .modal-card .row{display:grid;grid-template-columns:1fr;gap:8px}
  .card .row > .btn,
  .form .row > .btn,
  .modal-card .row > .btn,
  .card .row > .input,
  .form .row > .input,
  .modal-card .row > .input{width:100%}
}

@media (max-width: 640px){
  .sidebar{width:min(92vw,340px);padding:16px 12px 18px}
  .item .right{grid-template-columns:1fr}
  .content{padding:10px 8px 20px}
  .card{border-radius:14px}
  .list{padding:8px}
}


/* ===== v2.5 dashboard + mobile bottom nav ===== */
.dashboard-shell{display:grid;gap:14px}
.dashboard-hero{padding:14px}
.dashboard-hero-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}
.dashboard-hero-actions{display:flex;gap:10px;flex-wrap:wrap}
.dashboard-eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:900;color:rgba(56,189,248,.95);margin-bottom:6px}
.hero-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:14px}
.hero-stat-card{padding:14px;border-radius:18px;border:1px solid rgba(31,42,68,.78);background:linear-gradient(180deg, rgba(15,26,47,.72), rgba(10,18,34,.58))}
.hero-stat-card strong{display:block;font-size:28px;line-height:1.05;margin:8px 0 4px;font-weight:950}
.hero-stat-card small{display:block;color:var(--muted);font-size:12px;line-height:1.45}
.hero-stat-label{font-size:12px;font-weight:900;color:rgba(229,231,235,.86)}
.progress.compact{height:8px;margin-top:12px}
.dashboard-suggestion-row{display:grid;grid-template-columns:1.05fr .95fr;gap:10px;margin-top:12px}
.dashboard-suggestion-card{padding:14px;border-radius:18px;border:1px solid rgba(31,42,68,.78);background:rgba(15,26,47,.52)}
.dashboard-suggestion-card.is-empty{display:grid;align-content:center}
.dashboard-suggestion-title{font-size:12px;font-weight:900;color:rgba(56,189,248,.95);text-transform:uppercase;letter-spacing:.06em}
.dashboard-suggestion-main{font-size:22px;font-weight:950;line-height:1.1;margin:8px 0 6px}
.deadline-item{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid rgba(31,42,68,.65)}
.deadline-item:last-child{border-bottom:none;padding-bottom:0}
.deadline-item:first-of-type{padding-top:12px}
.deadline-item.late{color:#fecaca}
.dashboard-bottom-grid{align-items:stretch}
.checklist-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mini-check{display:flex;gap:10px;align-items:flex-start;padding:12px;border-radius:16px;border:1px solid rgba(31,42,68,.7);background:rgba(15,26,47,.42);font-weight:700;color:rgba(229,231,235,.9)}
.mini-check span{font-size:18px;line-height:1}
.mini-check.done{border-color:rgba(34,197,94,.28);background:rgba(34,197,94,.08)}
.pro-upsell-card{background:linear-gradient(180deg, rgba(15,26,47,.74), rgba(10,18,34,.62));border-color:rgba(56,189,248,.18)}
.pro-upsell-card.is-pro-user{border-color:rgba(34,197,94,.35)}
.free-usage-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.usage-chip{padding:12px;border-radius:16px;border:1px solid rgba(31,42,68,.78);background:rgba(15,26,47,.5)}
.usage-chip b{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}
.usage-chip span{display:block;font-size:22px;font-weight:950}
.dashboard-mini-item{align-items:center}
.week.week-compact{grid-template-columns:repeat(4,minmax(0,1fr))}
.compact-day{min-height:148px}
.pro-feature-box{margin-top:12px;padding:14px;border-radius:18px;border:1px solid rgba(56,189,248,.22);background:radial-gradient(340px 160px at 0% 0%, rgba(56,189,248,.12), transparent 60%), rgba(15,26,47,.58)}
.pro-feature-eyebrow{font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:rgba(56,189,248,.95)}
.pro-feature-title{font-size:22px;font-weight:950;line-height:1.1;margin-top:8px}
.pro-feature-text{margin-top:6px;color:rgba(229,231,235,.86);line-height:1.5}
.pro-feature-bullets{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.pro-feature-bullets span{padding:7px 10px;border-radius:999px;border:1px solid rgba(56,189,248,.24);background:rgba(56,189,248,.08);font-size:12px;font-weight:800}
.pro-feature-reason{margin-top:10px;color:#cbd5e1;font-size:12px}
.mobile-bottom-nav{display:none}
@media (max-width: 1100px){
  .hero-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .dashboard-suggestion-row,.week.week-compact{grid-template-columns:1fr}
}
@media (max-width: 900px){
  body{padding-bottom:84px}
  .content{padding-bottom:104px}
  .mobile-bottom-nav{position:fixed;left:10px;right:10px;bottom:10px;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;padding:8px;border-radius:22px;background:rgba(8,15,29,.92);border:1px solid rgba(31,42,68,.82);backdrop-filter:blur(10px);box-shadow:0 22px 60px rgba(0,0,0,.5);z-index:22}
  .mbnav-btn{border:none;background:transparent;color:var(--muted);padding:8px 6px;border-radius:16px;display:grid;place-items:center;gap:2px;font-weight:800;min-height:58px}
  .mbnav-btn span{font-size:18px;line-height:1}
  .mbnav-btn small{font-size:11px}
  .mbnav-btn.active{background:rgba(56,189,248,.12);color:#fff;box-shadow:0 0 0 1px rgba(56,189,248,.22) inset}
  .dashboard-hero{padding:12px}
  .dashboard-hero-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%}
  .dashboard-hero-actions .btn{width:100%}
  .hero-stat-grid,.dashboard-suggestion-row,.checklist-grid,.free-usage-grid{grid-template-columns:1fr}
  .dashboard-suggestion-main{font-size:20px}
  .compact-day{min-height:128px}
}
@media (max-width: 640px){
  .dashboard-hero-head{gap:10px}
  .dashboard-hero-actions{grid-template-columns:1fr}
  .hero-stat-card strong{font-size:24px}
  .mobile-bottom-nav{left:8px;right:8px;bottom:8px;padding:8px 6px;border-radius:18px}
  .mbnav-btn{min-height:54px;padding:6px 4px}
  .mbnav-btn span{font-size:17px}
  .mbnav-btn small{font-size:10px}
}


/* ===== v2.6 visual polish ===== */
:root{
  --bg:#07101d;
  --panel:#0b1527;
  --card:#0e1a31;
  --card2:#0b1629;
  --border:#24324e;
  --text:#f4f7fb;
  --muted:#93a4bd;
  --primary:#58c5ff;
  --primary2:#6ea8ff;
  --good:#34d399;
  --bad:#fb7185;
  --shadow:0 22px 60px rgba(0,0,0,.42);
  --shadow-soft:0 12px 28px rgba(0,0,0,.24);
  --radius:22px;
}
body{
  background:
    radial-gradient(1000px 560px at 12% -8%, rgba(88,197,255,.16), transparent 56%),
    radial-gradient(900px 520px at 88% -6%, rgba(110,168,255,.12), transparent 52%),
    linear-gradient(180deg, #07101d 0%, #081120 52%, #091426 100%);
}
.topbar{
  padding:16px 18px;
  background:linear-gradient(180deg, rgba(6,11,23,.96), rgba(8,15,29,.78));
  box-shadow:0 10px 30px rgba(0,0,0,.18);
}
.brand{gap:14px}
.logo{
  width:46px;height:46px;border-radius:16px;
  box-shadow:0 12px 28px rgba(88,197,255,.22), inset 0 1px 0 rgba(255,255,255,.18);
}
.brand-title{font-size:18px;font-weight:900;letter-spacing:-.02em}
.brand-sub{font-size:12px;color:#a9b8cc}
.topbar-actions{gap:12px}
.badge{
  padding:10px 14px;
  background:linear-gradient(180deg, rgba(14,26,49,.92), rgba(10,20,37,.86));
  border-color:rgba(88,197,255,.18);
  box-shadow:var(--shadow-soft);
}
.badge.pro{
  color:#d8fff1;
  background:linear-gradient(180deg, rgba(16,56,46,.82), rgba(11,33,31,.82));
  border-color:rgba(52,211,153,.34);
}
.btn{
  min-height:44px;
  padding:11px 15px;
  border-radius:16px;
  background:linear-gradient(180deg, rgba(18,29,53,.76), rgba(12,22,40,.78));
  border-color:rgba(88,197,255,.14);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.btn:hover{
  background:linear-gradient(180deg, rgba(20,33,60,.92), rgba(14,26,49,.92));
  border-color:rgba(88,197,255,.28);
  transform:translateY(-1px);
}
.btn.primary{
  color:#f8fcff;
  border-color:rgba(88,197,255,.46);
  background:linear-gradient(135deg, rgba(10,93,138,.58), rgba(54,110,255,.30));
  box-shadow:0 10px 24px rgba(19,86,199,.24), inset 0 1px 0 rgba(255,255,255,.08);
}
.btn.ghost{background:rgba(8,15,29,.28)}
.layout{height:calc(100% - 78px)}
.sidebar{
  padding:18px 14px;
  background:linear-gradient(180deg, rgba(10,17,31,.96), rgba(9,16,30,.78));
}
.nav{
  position:relative;
  min-height:48px;
  padding:12px 14px;
  border-radius:16px;
  color:#dfe8f4;
}
.nav-ico{
  width:26px;height:26px;border-radius:10px;display:grid;place-items:center;
  background:rgba(255,255,255,.03); box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}
.nav:hover{background:linear-gradient(180deg, rgba(15,27,49,.86), rgba(12,23,42,.78))}
.nav.active{
  background:linear-gradient(180deg, rgba(20,37,68,.96), rgba(13,26,47,.94));
  border-color:rgba(88,197,255,.34);
  box-shadow:0 14px 28px rgba(0,0,0,.24), inset 0 0 0 1px rgba(88,197,255,.10);
}
.nav.active .nav-ico{background:rgba(88,197,255,.12); color:#fff}
.pill{font-size:10px; letter-spacing:.04em; font-weight:900}
.sidebar-footer{display:none}
.content{padding:22px 22px 30px 22px}
.card{
  background:linear-gradient(180deg, rgba(13,24,45,.92), rgba(10,18,35,.88));
  border:1px solid rgba(88,197,255,.12);
  box-shadow:var(--shadow);
}
.h1{font-size:24px; letter-spacing:-.02em; margin-bottom:10px}
.h2{font-size:14px; color:#9eb0c8; line-height:1.55; margin-bottom:16px}
.input,select.input,textarea.input{
  min-height:46px;
  padding:12px 14px;
  border-radius:16px;
  background:linear-gradient(180deg, rgba(8,15,29,.82), rgba(10,19,35,.78));
}
.list{padding:14px}
.item{
  padding:13px 13px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(11,21,39,.90), rgba(10,19,35,.68));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.02);
}
.item:hover{transform:translateY(-1px); border-color:rgba(88,197,255,.18)}
.tag{padding:5px 9px;border-radius:999px}
.icon-btn{
  width:40px;height:40px;border-radius:14px;
  background:linear-gradient(180deg, rgba(18,29,53,.84), rgba(12,22,40,.84));
}
.modal-card{padding:18px;border-radius:26px}
.price-card,.day,.hero-stat-card,.dashboard-suggestion-card,.usage-chip,.mini-check,.kpi .k{
  border-radius:20px;
  border-color:rgba(88,197,255,.12);
}
.price-card.featured,
.pro-upsell-card{
  background:
    radial-gradient(520px 220px at 0% 0%, rgba(88,197,255,.13), transparent 58%),
    linear-gradient(180deg, rgba(13,25,47,.96), rgba(10,19,35,.88));
}
.dashboard-shell{gap:16px}
.dashboard-hero{padding:18px 18px 16px}
.dashboard-eyebrow{font-size:11px; letter-spacing:.12em}
.dashboard-hero-head{gap:18px}
.hero-stat-grid{gap:12px; margin-top:16px}
.hero-stat-card{
  padding:16px;
  background:linear-gradient(180deg, rgba(11,22,42,.96), rgba(8,17,32,.88));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}
.hero-stat-card strong{font-size:34px; letter-spacing:-.04em; margin-top:10px}
.hero-stat-card small{font-size:12px; line-height:1.55}
.hero-stat-label{font-size:12px; text-transform:none; color:#bad0e6}
.progress{height:11px; background:rgba(22,34,58,.92)}
.progress>div{background:linear-gradient(90deg, rgba(52,211,153,.78), rgba(88,197,255,.72))}
.dashboard-suggestion-row{gap:12px; margin-top:14px}
.dashboard-suggestion-card{padding:16px}
.dashboard-suggestion-title{font-size:11px; letter-spacing:.12em}
.dashboard-suggestion-main{font-size:24px; letter-spacing:-.03em}
.deadline-item{padding:12px 0}
.mini-check{padding:14px; font-weight:800}
.free-usage-grid{gap:12px}
.usage-chip{padding:14px}
.usage-chip span{font-size:24px}
.week{gap:12px}
.day{padding:12px; min-height:182px}
.day-title{font-size:13px}
.block{border-radius:16px; padding:10px; background:linear-gradient(180deg, rgba(88,197,255,.10), rgba(88,197,255,.06))}
.settings-panel,.mini-card{
  background:linear-gradient(180deg, rgba(11,22,42,.86), rgba(9,18,34,.78));
  border:1px solid rgba(88,197,255,.12);
  border-radius:20px;
}
.settings-panel{padding:16px}
.settings-panel-title{font-weight:900;font-size:16px}
.settings-panel-sub{color:#9eb0c8;line-height:1.5;margin-top:4px}
.mobile-bottom-nav{
  background:linear-gradient(180deg, rgba(7,13,24,.96), rgba(8,16,30,.92));
  border-color:rgba(88,197,255,.16);
}
.mbnav-btn.active{background:linear-gradient(180deg, rgba(19,37,68,.92), rgba(14,27,49,.92))}
#btnUpgrade{
  background:linear-gradient(135deg, rgba(7,103,76,.58), rgba(13,98,145,.42));
  border-color:rgba(52,211,153,.28);
}
@media (max-width: 1100px){
  .content{padding:18px 16px 28px}
}
@media (max-width: 900px){
  .topbar{padding:12px 12px 11px}
  .brand-title{font-size:16px}
  .btn{min-height:42px;padding:10px 12px}
  .dashboard-hero{padding:14px}
  .hero-stat-card strong{font-size:30px}
}
@media (max-width: 640px){
  .content{padding:10px 8px 20px}
  .card,.modal-card,.day,.price-card,.settings-panel{border-radius:18px}
  .hero-stat-card,.dashboard-suggestion-card,.usage-chip,.mini-check{border-radius:18px}
  .dashboard-suggestion-main{font-size:22px}
  .day{min-height:148px}
}


/* ===== v2.7 apple / saas luxe ===== */
:root{
  --bg:#060d18;
  --panel:#081120;
  --card:#0b1527;
  --card2:#0a1324;
  --border:#20304b;
  --text:#f7fbff;
  --muted:#90a4c0;
  --primary:#74d0ff;
  --primary2:#7aa5ff;
  --shadow:0 28px 80px rgba(0,0,0,.36);
  --shadow-soft:0 14px 28px rgba(0,0,0,.18);
  --radius:24px;
}
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(760px 360px at 15% 0%, rgba(255,255,255,.045), transparent 62%),
    radial-gradient(600px 320px at 86% 10%, rgba(116,208,255,.08), transparent 60%);
}
#app{position:relative; z-index:1}
.topbar{
  min-height:78px;
  padding:14px 18px;
  background:linear-gradient(180deg, rgba(7,13,24,.78), rgba(7,13,24,.58));
  border-bottom-color:rgba(255,255,255,.06);
  backdrop-filter:blur(18px) saturate(150%);
}
.logo{
  background:linear-gradient(135deg, rgba(116,208,255,.95), rgba(122,165,255,.8));
  box-shadow:0 18px 34px rgba(55,125,255,.22), inset 0 1px 0 rgba(255,255,255,.22);
}
.brand-title{font-size:19px;font-weight:950}
.brand-sub{color:#adc0d8}
.topbar-actions{gap:10px;align-items:center}
.topbar-actions > .btn,.topbar-actions > .badge{backdrop-filter:blur(12px)}
.badge{
  background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.03));
  border-color:rgba(255,255,255,.08);
  box-shadow:0 10px 26px rgba(0,0,0,.14), inset 0 1px 0 rgba(255,255,255,.05);
}
.badge.pro{background:linear-gradient(180deg, rgba(12,76,55,.72), rgba(7,49,40,.7))}
.btn{
  border-radius:999px;
  min-height:46px;
  padding:11px 16px;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border-color:rgba(255,255,255,.07);
  box-shadow:0 10px 24px rgba(0,0,0,.12), inset 0 1px 0 rgba(255,255,255,.05);
}
.btn:hover{background:linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.03));border-color:rgba(255,255,255,.10)}
.btn.primary,#btnUpgrade{
  background:linear-gradient(135deg, rgba(18,117,176,.9), rgba(65,97,255,.72));
  border-color:rgba(160,205,255,.30);
  box-shadow:0 16px 28px rgba(38,99,235,.18), inset 0 1px 0 rgba(255,255,255,.10);
}
.layout{grid-template-columns:300px minmax(0,1fr)}
.sidebar{
  padding:18px 14px;
  background:linear-gradient(180deg, rgba(9,16,29,.88), rgba(9,16,29,.68));
  border-right-color:rgba(255,255,255,.06);
  backdrop-filter:blur(16px);
}
.nav{
  min-height:50px;
  border-radius:18px;
  color:#dfe8f6;
  border-color:transparent;
}
.nav:hover{background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.028));border-color:rgba(255,255,255,.06)}
.nav.active{
  background:linear-gradient(180deg, rgba(22,38,68,.94), rgba(13,25,45,.92));
  border-color:rgba(116,208,255,.22);
  box-shadow:0 16px 28px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.05);
}
.nav-ico{
  width:28px; height:28px; border-radius:12px;
  background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025));
}
.content{padding:24px 24px 34px}
.card,.modal-card,.day,.hero-stat-card,.dashboard-suggestion-card,.usage-chip,.mini-check,.kpi .k,.price-card,.settings-panel,.mini-card{
  background:linear-gradient(180deg, rgba(14,24,42,.84), rgba(8,15,29,.86));
  border:1px solid rgba(255,255,255,.075);
  box-shadow:0 28px 70px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.04);
  backdrop-filter:blur(16px);
}
.h1{font-size:26px;letter-spacing:-.03em}
.h2{color:#adc0d8}
.input,select.input,textarea.input{
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018));
  border-color:rgba(255,255,255,.07);
}
.input:focus, select.input:focus, textarea.input:focus{border-color:rgba(116,208,255,.32);box-shadow:0 0 0 4px rgba(116,208,255,.08)}
.item{
  border-radius:20px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.016));
  border-color:rgba(255,255,255,.06);
}
.item:hover{border-color:rgba(116,208,255,.16);box-shadow:0 14px 28px rgba(0,0,0,.14), inset 0 1px 0 rgba(255,255,255,.04)}
.kbd,.tag,.pill{border-color:rgba(255,255,255,.08)}
.dashboard-hero{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(620px 260px at 100% 0%, rgba(116,208,255,.10), transparent 58%),
    linear-gradient(180deg, rgba(12,23,41,.92), rgba(8,15,29,.92));
}
.dashboard-hero::after{
  content:""; position:absolute; right:-46px; top:-46px; width:220px; height:220px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.08), transparent 68%); pointer-events:none;
}
.dashboard-hero-actions .btn{box-shadow:none}
.hero-stat-card strong{font-size:36px}
.hero-stat-card,.dashboard-suggestion-card,.usage-chip,.mini-check{border-radius:22px}
.progress{background:rgba(255,255,255,.06)}
.progress>div{background:linear-gradient(90deg, rgba(52,211,153,.9), rgba(116,208,255,.85))}
.block{border-color:rgba(116,208,255,.16);background:linear-gradient(180deg, rgba(116,208,255,.10), rgba(116,208,255,.04))}
.modal-card{border-radius:30px;padding:20px}
.pro-feature-box{
  background:radial-gradient(460px 180px at 0% 0%, rgba(116,208,255,.12), transparent 58%), linear-gradient(180deg, rgba(14,24,42,.92), rgba(9,16,31,.90));
  border-color:rgba(116,208,255,.18);
}
.mobile-bottom-nav{
  background:linear-gradient(180deg, rgba(7,13,24,.82), rgba(7,13,24,.66));
  border-color:rgba(255,255,255,.08);
  backdrop-filter:blur(18px);
}
.mbnav-btn.active{background:linear-gradient(180deg, rgba(22,38,68,.90), rgba(12,24,44,.88)); box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
@media (max-width:900px){
  .topbar{padding:12px}
  .content{padding:14px 12px 110px}
  .sidebar{background:linear-gradient(180deg, rgba(8,14,25,.96), rgba(8,14,25,.90))}
}
@media (max-width:640px){
  .btn{min-height:44px}
  .h1{font-size:23px}
  .hero-stat-card strong{font-size:30px}
}

/* ===== v3.3 simplificação de navegação e home ===== */
.sidebar-section-label{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:rgba(144,164,192,.82);font-weight:900;margin:4px 6px 10px}
.nav-group{margin-top:10px;border:1px solid rgba(31,42,68,.55);border-radius:18px;background:rgba(10,18,34,.42);overflow:hidden}
.nav-group + .nav-group{margin-top:12px}
.nav-group-summary{list-style:none;cursor:pointer;padding:12px 14px;font-weight:850;color:var(--text);display:flex;align-items:center;justify-content:space-between}
.nav-group-summary::-webkit-details-marker{display:none}
.nav-group-summary::after{content:"▾";color:var(--muted);font-size:12px;transition:transform .18s ease}
.nav-group[open] .nav-group-summary::after{transform:rotate(180deg)}
.nav-group-items{padding:0 8px 8px}
.nav-group .nav{margin-bottom:6px}
.nav-group-pro .pill{margin-left:8px}
.nav-group[open]{box-shadow:0 12px 28px rgba(2,6,23,.16)}
@media (max-width: 900px){
  .nav-group{flex:0 0 auto}
  .nav-group-items{padding-bottom:10px}
  .nav-group .nav:last-child{margin-bottom:0}
}
.dashboard-shell-simple{gap:16px}
.dashboard-hero-simple{padding:18px}
.dashboard-hero-head-simple{align-items:flex-start}
.dashboard-hero-actions-simple{display:flex;gap:10px;flex-wrap:wrap}
.hero-stat-grid-simple{grid-template-columns:repeat(2,minmax(0,1fr));max-width:620px}
.dashboard-main-grid-simple{grid-template-columns:1fr 1fr}
.dashboard-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.focus-next-card{padding:16px;border-radius:18px;border:1px solid rgba(56,189,248,.18);background:linear-gradient(180deg, rgba(12,24,45,.9), rgba(9,17,32,.78))}
.focus-next-card.is-empty{border-color:rgba(31,42,68,.8)}
.focus-next-title{font-size:24px;font-weight:950;line-height:1.1;margin-bottom:6px;letter-spacing:-.03em}
.dashboard-mini-list{display:grid;gap:8px}
.dashboard-mini-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-radius:14px;border:1px solid rgba(31,42,68,.7);background:rgba(15,26,47,.4);font-weight:800}
.dashboard-mini-row.is-alert{border-color:rgba(239,68,68,.32)}
.dashboard-task-row{padding:12px 12px}
.dashboard-kpi-simple{grid-template-columns:1fr 1fr;gap:10px}
.dashboard-secondary-actions{flex-wrap:wrap}
@media (max-width: 1100px){.dashboard-main-grid-simple{grid-template-columns:1fr}}
@media (max-width: 900px){.hero-stat-grid-simple{grid-template-columns:1fr}.dashboard-hero-actions-simple{display:grid;grid-template-columns:1fr 1fr;width:100%}.dashboard-hero-actions-simple .btn{width:100%}}
@media (max-width: 640px){.dashboard-hero-actions-simple{grid-template-columns:1fr}.dashboard-section-head{flex-direction:column;align-items:stretch}.focus-next-title{font-size:22px}.dashboard-kpi-simple{grid-template-columns:1fr}.nav-group-summary{padding:11px 13px}}


/* v3.3.4 simplificação calendário + cronograma */
.simple-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;}
.mini-card{border:1px solid rgba(31,42,68,.75);background:rgba(15,26,47,.48);border-radius:18px;padding:14px;}
.mini-card-value{font-size:28px;font-weight:950;line-height:1.05;margin-top:8px;}
.mini-card-value.mini-card-small{font-size:18px;}
.simple-split{display:grid;grid-template-columns:1.2fr .9fr;gap:14px;}
.section-title{font-size:18px;font-weight:900;margin-bottom:4px;}
.compact-item{padding-top:12px;padding-bottom:12px;}
.empty-state{border:1px dashed rgba(88,112,158,.45);border-radius:16px;padding:18px;text-align:left;background:rgba(255,255,255,.02);}
.empty-state-title{font-size:16px;font-weight:900;margin-bottom:6px;}
.day-list-simple{display:grid;gap:10px;}
.day-line{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;text-align:left;border:1px solid rgba(31,42,68,.75);background:rgba(255,255,255,.02);border-radius:16px;padding:12px;color:var(--text);}
.day-line.today-line{box-shadow:0 0 0 1px rgba(56,189,248,.22) inset;}
.day-line-title{font-weight:900;font-size:14px;}
.calendar-simple-layout{align-items:start;}
.cal-cell-simple{min-height:72px;}
.cal-dot-row{display:flex;flex-direction:column;gap:5px;margin-top:8px;}
.cal-count-pill{display:inline-flex;align-items:center;justify-content:center;width:max-content;max-width:100%;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:800;background:rgba(56,189,248,.12);border:1px solid rgba(56,189,248,.22);color:var(--text);}
.cal-count-pill.subtle{background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.08);}
@media (max-width: 1024px){.simple-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr));}.simple-split{grid-template-columns:1fr;}}
@media (max-width: 640px){.simple-stat-grid{grid-template-columns:1fr;}.mini-card{padding:12px;}.mini-card-value{font-size:24px;}.section-title{font-size:16px;}.day-line{padding:10px;align-items:flex-start;flex-direction:column;}.day-line .right{width:100%;display:flex;gap:8px;justify-content:flex-start;}.cal-grid{gap:6px;}.cal-cell-simple{min-height:64px;padding:6px;}.cal-count-pill{font-size:10px;padding:2px 6px;}}


/* ===== v3.3.7 mobile-first header cleanup ===== */
.nav-mobile-extra{display:none;text-decoration:none}
@media (max-width: 900px){
  body{padding-bottom:82px}
  .topbar{padding:10px 12px;gap:10px;align-items:center}
  .brand{min-width:0;flex:1;gap:10px}
  .logo{width:38px;height:38px;border-radius:14px;flex:0 0 38px}
  .brand-title{font-size:16px;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .brand-sub{display:none}
  .topbar-actions{width:auto;display:flex;align-items:center;gap:8px;margin-left:auto}
  .topbar-actions .cloud-row{display:flex;align-items:center;gap:8px;margin:0}
  .topbar-actions #cloudStatusBadge{display:none}
  .topbar-actions .mobile-menu-btn,
  .topbar-actions #planBadge,
  .topbar-actions #btnUpgrade,
  .topbar-actions a[href="../"]{display:none !important}
  .topbar-actions #btnCloudAccount,
  .topbar-actions .btn{min-height:40px;padding:10px 14px;border-radius:14px;font-size:14px}
  .content{padding:10px 10px 100px}
  .dashboard-shell{gap:10px}
  .dashboard-hero{padding:12px}
  .dashboard-hero-head{gap:10px}
  .dashboard-hero-actions{grid-template-columns:1fr 1fr;gap:8px}
  .hero-stat-card{padding:12px;border-radius:16px}
  .hero-stat-card strong{font-size:22px}
  .dashboard-suggestion-card{padding:12px;border-radius:16px}
  .dashboard-suggestion-main{font-size:19px}
  .nav-mobile-extra{display:flex}
  .sidebar::before{content:"Mais"}
}
@media (max-width: 640px){
  .topbar{padding:8px 10px}
  .brand{gap:9px}
  .logo{width:36px;height:36px;border-radius:13px;flex-basis:36px}
  .brand-title{font-size:15px}
  .topbar-actions #btnCloudAccount{min-height:38px;padding:9px 12px;font-size:13px}
  .dashboard-hero{padding:10px}
  .dashboard-hero-actions{grid-template-columns:1fr}
  .hero-stat-card{padding:11px}
  .hero-stat-label,.hero-stat-card small{font-size:11px}
  .hero-stat-card strong{font-size:20px}
  .dashboard-suggestion-main{font-size:18px}
}


/* ===== v3.3.8 desktop polish ===== */
@media (min-width: 901px){
  .topbar{
    min-height:74px;
    padding:14px 18px;
    gap:18px;
  }
  .brand{gap:14px;}
  .brand-sub{font-size:12px;opacity:.92;}
  .topbar-actions{
    margin-left:auto;
    display:flex;
    align-items:center;
    gap:8px;
    padding:8px;
    border-radius:22px;
    border:1px solid rgba(255,255,255,.07);
    background:linear-gradient(180deg, rgba(255,255,255,.038), rgba(255,255,255,.018));
    box-shadow:0 18px 36px rgba(2,8,23,.18), inset 0 1px 0 rgba(255,255,255,.045);
    backdrop-filter:blur(16px) saturate(130%);
  }
  .topbar-actions .cloud-row{
    order:1;
    display:flex;
    align-items:center;
    gap:8px;
    margin:0 6px 0 0;
    padding-right:8px;
    border-right:1px solid rgba(255,255,255,.06);
  }
  .topbar-actions #cloudStatusBadge{
    display:inline-flex;
    align-items:center;
    min-height:42px;
    padding:10px 14px;
    border-radius:999px;
    font-size:13px;
    font-weight:850;
    color:#d7fff0;
    background:linear-gradient(180deg, rgba(12,81,58,.56), rgba(8,53,40,.50));
    border:1px solid rgba(52,211,153,.22);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
    white-space:nowrap;
  }
  .topbar-actions #btnCloudAccount{
    min-height:42px;
    padding:10px 16px;
    border-radius:16px;
    background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  }
  .topbar-actions a[href="../"]{
    order:5;
    min-height:42px;
    padding:0 10px;
    border:none;
    background:transparent;
    color:#cad8ea;
    box-shadow:none;
    text-decoration:none;
    opacity:.88;
  }
  .topbar-actions a[href="../"]:hover{
    background:rgba(255,255,255,.035);
    border-radius:14px;
    opacity:1;
  }
  .topbar-actions #planBadge{
    order:3;
    min-height:42px;
    padding:9px 14px;
    border-radius:999px;
    font-size:13px;
    letter-spacing:.02em;
    color:#f1f6ff;
    background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.024));
  }
  .topbar-actions #btnUpgrade{
    order:4;
    min-height:42px;
    padding:10px 18px;
    border-radius:16px;
  }
  .dashboard-shell{gap:14px;}
  .dashboard-hero-simple{padding:16px 18px 15px;}
  .dashboard-hero-head-simple{align-items:center;}
  .dashboard-hero-actions-simple{gap:8px;}
  .dashboard-hero-actions-simple .btn{min-height:42px;}
  .hero-stat-grid-simple{max-width:none; gap:10px;}
  .hero-stat-card{padding:14px 16px;}
  .hero-stat-card strong{font-size:30px; margin-top:8px;}
  .focus-next-card{padding:15px 16px;}
  .focus-next-title{font-size:22px;}
}


/* ===== v3.3.11 mobile sidebar grouping fix ===== */
.nav-group-more .nav-group-summary{font-size:15px}
@media (max-width: 900px){
  .nav-group{overflow:visible}
  .nav-group-items{padding:0 6px 10px}
  .nav-group .nav{margin-bottom:8px}
  .nav-group .nav:last-child{margin-bottom:0}
  .nav-group-summary{padding:13px 14px}
  .nav-group-more .nav-mobile-extra{display:flex}
}


/* v3.3.12 — dark selects across app/admin */
:root { color-scheme: dark; }
html, body { color-scheme: dark; }
select,
select.input,
option,
optgroup {
  color-scheme: dark;
}
select.input,
select {
  -webkit-appearance: none;
  appearance: none;
  background-color: rgba(10,18,34,.96);
  background-image:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015)),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23dbeafe' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat, no-repeat;
  background-position: center, right 14px center;
  background-size: auto, 16px;
  padding-right: 44px;
}
select option,
select.input option,
select optgroup {
  background: #08131f;
  color: #f8fbff;
}
select option:checked,
select.input option:checked {
  background: #16396b;
  color: #ffffff;
}
select option:hover,
select.input option:hover {
  background: #102947;
}
