/* TMC Schedule - mockup design tokens + components (light default, dark via [data-theme="dark"])
   Tokens extraidos do app real (CleanProof/TMC) + paleta light do design system.
   Linkar este arquivo em todas as paginas; o tema e controlado por tmc.js. */

/* ---------- tokens ---------- */
:root{
  /* light (paleta do design system) */
  --paper:#F6F2EA; --surface:#FFFDF8; --surface2:#F1ECE1;
  --ink:#16201C; --muted:#6E7B73;
  --line:#E7E0D3; --line-strong:#DBD2C2;
  --brand:#0E7C6B; --brand-soft:rgba(14,124,107,.12); --brand-ink:#0E7C6B;
  --accent:#E07B3C; --accent-soft:rgba(224,123,60,.14);
  --success:#1F9D57; --success-soft:rgba(31,157,87,.13);
  --danger:#C9533B; --danger-soft:rgba(201,83,59,.13);
  --warn:#D9A441; --warn-soft:rgba(217,164,65,.16);
  --on-brand:#FFFFFF; --on-accent:#2A1606; --on-success:#FFFFFF; --on-danger:#FFFFFF;
  --radius:12px; --radius-lg:20px;
  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --shadow:0 1px 2px rgba(22,32,28,.06), 0 8px 24px -14px rgba(22,32,28,.30);
  --shadow-phone:0 30px 60px -30px rgba(22,32,28,.45);
  --glow-teal:rgba(14,124,107,.14); --glow-warm:rgba(224,123,60,.12);
}
:root[data-theme="dark"]{
  /* dark (paleta aprovada da mockup atual) */
  --paper:#0F1311; --surface:#18201D; --surface2:#1E2824;
  --ink:#EAEFEC; --muted:#9DACA3;
  --line:rgba(231,224,211,.10); --line-strong:rgba(231,224,211,.16);
  --brand:#19B89E; --brand-soft:rgba(25,184,158,.14); --brand-ink:#0E7C6B;
  --accent:#F0894A; --accent-soft:rgba(240,137,74,.16);
  --success:#2BB468; --success-soft:rgba(43,180,104,.16);
  --danger:#E27358; --danger-soft:rgba(226,115,88,.16);
  --warn:#E6B85C; --warn-soft:rgba(230,184,92,.16);
  --on-brand:#04231e; --on-accent:#1a1207; --on-success:#042b14; --on-danger:#2a0f08;
  --shadow:0 10px 30px -16px rgba(0,0,0,.7);
  --shadow-phone:0 30px 70px -28px rgba(0,0,0,.8);
  --glow-teal:rgba(25,184,158,.16); --glow-warm:rgba(240,137,74,.12);
}

*{box-sizing:border-box}
html,body{margin:0}
body{
  background:
    radial-gradient(60% 38% at 50% -4%, var(--glow-teal), transparent 70%),
    radial-gradient(46% 32% at 100% 0%, var(--glow-warm), transparent 70%),
    var(--paper);
  color:var(--ink); font-family:"Hanken Grotesk",system-ui,sans-serif; min-height:100vh;
  -webkit-font-smoothing:antialiased; padding:84px 24px 100px;
}
a{color:inherit}

/* ---------- page heading ---------- */
.page-head{max-width:1240px; margin:0 auto 30px}
.page-head .eyebrow{font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--brand)}
.page-head h1{font-family:"Fraunces",serif; font-weight:600; font-size:32px; letter-spacing:-.02em; margin:.3em 0 .15em}
.page-head p{color:var(--muted); max-width:70ch; line-height:1.55; margin:0; font-size:15px}

/* ---------- frame grid ---------- */
.grid{max-width:1240px; margin:0 auto; display:flex; flex-wrap:wrap; gap:40px 32px; justify-content:center; align-items:flex-start}
.frame{width:344px}
.frame > .label{font-family:var(--mono); font-size:11px; letter-spacing:.13em; text-transform:uppercase; color:var(--muted); margin:0 0 10px 4px}
.frame > .label b{color:var(--ink); font-weight:600}
.frame > .note{font-size:12.5px; color:var(--muted); line-height:1.5; margin:10px 4px 0}
.frame > .note b{color:var(--ink); font-weight:600}

.phone{background:var(--surface); border:1px solid var(--line-strong); border-radius:38px; padding:10px; box-shadow:var(--shadow-phone); position:relative}
.screen{
  background:radial-gradient(72% 28% at 50% 0%, var(--glow-teal), transparent 70%), var(--paper);
  border-radius:29px; overflow:hidden; height:712px; display:flex; flex-direction:column; position:relative;
}
.screen.tall{height:792px}
.screen.short{height:560px}

/* desktop frame (gestora no laptop) */
.deskframe{width:720px}
.desk{background:var(--surface); border:1px solid var(--line-strong); border-radius:16px; overflow:hidden; box-shadow:var(--shadow-phone)}
.desk .bar{display:flex; gap:6px; padding:11px 14px; border-bottom:1px solid var(--line); background:var(--surface2)}
.desk .bar i{width:11px; height:11px; border-radius:999px; background:var(--line-strong); display:block}
.desk .view{height:480px; overflow:hidden; background:radial-gradient(60% 30% at 50% 0%, var(--glow-teal), transparent 70%), var(--paper)}

/* ---------- chrome inside screen ---------- */
.statusbar{display:flex; align-items:center; justify-content:space-between; padding:13px 20px 6px; font-family:var(--mono); font-size:11px; color:var(--muted)}
.topbar{padding:6px 18px 12px; display:flex; align-items:center; gap:10px; border-bottom:1px solid var(--line)}
.topbar .title{font-family:"Fraunces",serif; font-weight:600; font-size:20px; letter-spacing:-.01em}
.topbar .spacer{flex:1}
.body{flex:1; overflow:auto; padding:14px 16px; display:flex; flex-direction:column; gap:12px}
.body::-webkit-scrollbar{width:0}

/* ---------- type helpers ---------- */
.eyebrow{font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--brand)}
.muted{color:var(--muted)}
.mono{font-family:var(--mono); font-variant-numeric:tabular-nums}
.name{font-family:"Fraunces",serif; font-weight:600; font-size:17px; letter-spacing:-.01em}
.h2{font-family:"Fraunces",serif; font-weight:600; font-size:22px; letter-spacing:-.015em; margin:0}
.sub{font-size:13px; color:var(--muted); display:flex; align-items:center; gap:6px}
.price{font-family:var(--mono); font-weight:600; font-size:15px; font-variant-numeric:tabular-nums}
.row{display:flex; align-items:center; gap:10px}
.col{display:flex; flex-direction:column}
.between{justify-content:space-between}
.wrap{flex-wrap:wrap}

/* ---------- cards ---------- */
.card{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:14px; box-shadow:var(--shadow)}
.card.flat{box-shadow:none}
.card.done{background:var(--success-soft); border-color:color-mix(in srgb, var(--success) 35%, transparent)}
.card.alert{background:var(--danger-soft); border-color:color-mix(in srgb, var(--danger) 35%, transparent)}
.card.warnote{background:var(--warn-soft); border-color:color-mix(in srgb, var(--warn) 40%, transparent)}
.card.brandwash{background:var(--brand-soft); border-color:color-mix(in srgb, var(--brand) 32%, transparent)}
.card.tap{cursor:pointer; transition:transform .12s, box-shadow .15s}
.card.tap:hover{transform:translateY(-2px); box-shadow:0 14px 30px -16px rgba(22,32,28,.4)}

/* ---------- pills / badges ---------- */
.pill{display:inline-flex; align-items:center; gap:6px; font-size:11px; font-weight:600; padding:4px 9px; border-radius:999px; background:var(--brand-soft); color:var(--brand)}
.pill.accent{background:var(--accent-soft); color:var(--accent)}
.pill.ok{background:var(--success-soft); color:var(--success)}
.pill.bad{background:var(--danger-soft); color:var(--danger)}
.pill.warn{background:var(--warn-soft); color:var(--warn)}
.pill.ghost{background:transparent; color:var(--muted); border:1px solid var(--line-strong)}
.dot{width:8px; height:8px; border-radius:999px; display:inline-block}

/* ---------- buttons ---------- */
.btn{display:flex; align-items:center; justify-content:center; gap:8px; width:100%; border:0; border-radius:14px; padding:12px; font-family:inherit; font-weight:700; font-size:14px; cursor:pointer; margin-top:12px; transition:transform .1s}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--accent); color:var(--on-accent)}
.btn.brand{background:var(--brand); color:var(--on-brand)}
.btn.green{background:var(--success); color:var(--on-success)}
.btn.danger{background:var(--danger); color:var(--on-danger)}
.btn.ghost{background:transparent; color:var(--muted); border:1px solid var(--line-strong); font-weight:600}
.btn.sm{padding:9px 12px; font-size:13px; margin-top:0; width:auto}

/* ---------- avatar ---------- */
.avatar{width:28px; height:28px; border-radius:999px; background:var(--brand-soft); color:var(--brand); display:grid; place-items:center; font-size:12px; font-weight:700; font-family:var(--mono); flex:none}
.avatar.lg{width:44px; height:44px; font-size:16px}

/* ---------- segmented / switch / fields / tabs ---------- */
.seg{display:flex; gap:6px}
.seg .opt{flex:1; text-align:center; padding:9px 0; border-radius:10px; border:1px solid var(--line); font-size:13px; color:var(--muted); cursor:pointer}
.seg .opt.on{background:var(--brand-soft); border-color:var(--brand); color:var(--brand); font-weight:700}
.field{border:1px solid var(--line); border-radius:12px; padding:10px 12px; background:var(--surface)}
.field .k{font-size:11px; color:var(--muted)}
.field .v{font-size:15px; margin-top:2px}
.field.focus{border-color:var(--brand); box-shadow:0 0 0 3px var(--brand-soft)}
.switch{width:42px; height:25px; border-radius:999px; background:var(--line-strong); position:relative; flex:none; cursor:pointer}
.switch i{position:absolute; top:3px; left:3px; width:19px; height:19px; border-radius:999px; background:var(--surface); box-shadow:0 1px 3px rgba(0,0,0,.3); transition:left .15s}
.switch.on{background:var(--success)}
.switch.on i{left:20px; background:#fff}
.tabs{display:flex; gap:18px; border-bottom:1px solid var(--line); padding:0 2px}
.tabs .tab{padding:9px 0; font-size:13px; font-weight:600; color:var(--muted); border-bottom:2px solid transparent; margin-bottom:-1px; cursor:pointer}
.tabs .tab.on{color:var(--ink); border-color:var(--accent)}

/* ---------- progress / ring ---------- */
.progress{height:7px; border-radius:999px; background:var(--line-strong); overflow:hidden; margin-top:8px}
.progress > i{display:block; height:100%; background:var(--accent)}
.ring{width:46px; height:46px; flex:none}

/* ---------- list rows (clientes, faturas, servicos) ---------- */
.list{display:flex; flex-direction:column}
.lrow{display:flex; align-items:center; gap:11px; padding:11px 2px; border-bottom:1px solid var(--line)}
.lrow:last-child{border-bottom:0}
.lrow .grow{flex:1; min-width:0}
.lrow .t{font-weight:600; font-size:14.5px}
.lrow .s{font-size:12px; color:var(--muted); margin-top:1px}

/* ---------- proof photos ---------- */
.proof{border-radius:14px; overflow:hidden; border:1px solid var(--line); position:relative; aspect-ratio:3/4; background:linear-gradient(160deg,#2a3a34,#16201c)}
.proof .cap{position:absolute; left:8px; bottom:8px; right:8px; font-family:var(--mono); font-size:9px; letter-spacing:.04em; color:#dfeee7; background:rgba(8,12,11,.55); backdrop-filter:blur(6px); border-radius:8px; padding:5px 7px; display:flex; justify-content:space-between}
.vbadge{position:absolute; top:8px; right:8px; background:var(--success); color:#042b14; font-size:10px; font-weight:700; padding:3px 8px; border-radius:999px; display:flex; align-items:center; gap:4px}
.proofgrid{display:grid; grid-template-columns:1fr 1fr; gap:8px}
.proofgrid.three{grid-template-columns:1fr 1fr 1fr}

/* ---------- calendar ---------- */
.cal{display:grid; grid-template-columns:repeat(7,1fr); gap:4px}
.cal .dow{font-family:var(--mono); font-size:9px; text-transform:uppercase; letter-spacing:.1em; color:var(--muted); text-align:center; padding-bottom:3px}
.cal .d{aspect-ratio:1; border-radius:9px; border:1px solid var(--line); font-size:12px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px; color:var(--muted); position:relative}
.cal .d.in{color:var(--ink)}
.cal .d.today{border-color:var(--accent); color:var(--ink); font-weight:700}
.cal .d.sel{background:var(--brand-soft); border-color:var(--brand); color:var(--brand); font-weight:700}
.cal .d .dots{display:flex; gap:2px}

/* ---------- map / route ---------- */
.map{flex:none; height:200px; border-radius:16px; border:1px solid var(--line); position:relative; overflow:hidden;
  background:radial-gradient(circle at 30% 35%, var(--glow-teal), transparent 30%),
            radial-gradient(circle at 62% 55%, var(--glow-warm), transparent 28%),
            linear-gradient(180deg,#16241f,#101714);}
.map .road{position:absolute; background:rgba(231,224,211,.10)}
.pin{position:absolute; width:22px; height:22px; transform:translate(-50%,-100%); color:var(--accent)}
.pin .n{position:absolute; top:-2px; left:50%; transform:translate(-50%,-100%); font-family:var(--mono); font-size:9px; color:var(--ink); background:var(--surface); border:1px solid var(--line); border-radius:6px; padding:0 4px}

/* ---------- dashboard stats ---------- */
.stats{display:grid; grid-template-columns:1fr 1fr; gap:10px}
.stat{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:12px; box-shadow:var(--shadow)}
.stat .k{font-family:var(--mono); font-size:9.5px; text-transform:uppercase; letter-spacing:.12em; color:var(--muted)}
.stat .v{font-family:"Fraunces",serif; font-weight:600; font-size:24px; margin-top:4px; letter-spacing:-.01em}
.stat .v small{font-size:13px; color:var(--muted); font-family:var(--mono); font-weight:400}

/* ---------- bottom nav ---------- */
.nav{display:flex; border-top:1px solid var(--line); padding:9px 6px 16px; background:var(--surface); flex:none}
.nav .t{flex:1; text-align:center; color:var(--muted); font-size:10px; display:flex; flex-direction:column; align-items:center; gap:4px; cursor:pointer}
.nav .t.on{color:var(--brand)}

/* ---------- misc ---------- */
.brandmark{width:28px; height:28px; border-radius:8px; background:var(--brand); display:grid; place-items:center; color:var(--on-brand); flex:none}
.wm{font-family:"Fraunces",serif; font-weight:600; font-size:15px; letter-spacing:-.01em}
svg{display:block}
.ico{width:18px; height:18px; stroke:currentColor; stroke-width:2; fill:none; stroke-linecap:round; stroke-linejoin:round; flex:none}
.ico.sm{width:14px; height:14px}
.ico.lg{width:22px; height:22px}
.ib{display:inline; vertical-align:-2px}
.legend{max-width:1240px; margin:36px auto 0; color:var(--muted); font-size:13px; line-height:1.65}
.legend b{color:var(--ink)}
hr.sep{border:0; border-top:1px solid var(--line); margin:2px 0}

/* ---------- top flow nav (injected by tmc.js) ---------- */
#tmcnav{position:fixed; top:0; left:0; right:0; z-index:50; display:flex; align-items:center; gap:14px;
  padding:10px 18px; background:color-mix(in srgb, var(--paper) 86%, transparent); backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line); font-size:13px}
#tmcnav .brand{display:flex; align-items:center; gap:8px; font-weight:700}
#tmcnav .links{display:flex; gap:4px; flex-wrap:wrap; flex:1}
#tmcnav a.lk{padding:6px 11px; border-radius:999px; color:var(--muted); text-decoration:none; font-weight:600}
#tmcnav a.lk:hover{background:var(--surface2); color:var(--ink)}
#tmcnav a.lk.on{background:var(--brand-soft); color:var(--brand)}
#tmcnav .toggle{display:flex; align-items:center; gap:7px; border:1px solid var(--line-strong); background:var(--surface);
  color:var(--ink); border-radius:999px; padding:6px 12px; cursor:pointer; font-family:inherit; font-weight:600; font-size:12.5px}

/* ---------- sitemap (index) ---------- */
.map-grid{max-width:1100px; margin:0 auto; display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:18px}
.flowcard{display:block; text-decoration:none; color:inherit; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:20px; box-shadow:var(--shadow); transition:transform .12s, box-shadow .15s}
.flowcard:hover{transform:translateY(-3px); box-shadow:0 16px 34px -18px rgba(22,32,28,.45)}
.flowcard .ic{width:44px; height:44px; border-radius:12px; background:var(--brand-soft); color:var(--brand); display:grid; place-items:center; margin-bottom:14px}
.flowcard h3{font-family:"Fraunces",serif; font-weight:600; font-size:19px; margin:0 0 6px; letter-spacing:-.01em}
.flowcard p{margin:0; color:var(--muted); font-size:13.5px; line-height:1.5}
.flowcard .n{font-family:var(--mono); font-size:11px; color:var(--accent); margin-top:12px; display:block}

/* ---------- clickable prototype (one screen at a time) ---------- */
body.proto{padding:64px 16px 40px}
.stage{display:flex; justify-content:center; padding-top:6px}
body.proto .screen{display:none}
body.proto .screen.show{display:flex; animation:rise .28s var(--ease,cubic-bezier(.22,1,.36,1))}
.webscreen{display:none}
.webscreen.show{display:block; animation:rise .28s cubic-bezier(.22,1,.36,1)}
@keyframes rise{from{opacity:0; transform:translateY(8px)} to{opacity:1; transform:none}}
@media (prefers-reduced-motion:reduce){ body.proto .screen.show,.webscreen.show{animation:none} }
[data-go],[data-back]{cursor:pointer}

/* persona picker (mobile prototype home) */
.persona{display:flex; flex-direction:column; gap:12px; justify-content:center; height:100%; padding:22px 18px}
.persona .pick{display:flex; align-items:center; gap:13px; text-align:left; width:100%; border:1px solid var(--line); background:var(--surface); border-radius:var(--radius-lg); padding:16px; box-shadow:var(--shadow); cursor:pointer; font:inherit; color:inherit}
.persona .pick:active{transform:translateY(1px)}
.persona .pick .ic{width:44px; height:44px; border-radius:12px; background:var(--brand-soft); color:var(--brand); display:grid; place-items:center; flex:none}
.persona .pick .t{font-family:"Fraunces",serif; font-weight:600; font-size:17px}
.persona .pick .d{font-size:12.5px; color:var(--muted); margin-top:2px}

/* ---------- desktop admin shell (web prototype) ---------- */
.adminwin{width:1040px; max-width:100%; margin:0 auto; border:1px solid var(--line-strong); border-radius:14px; overflow:hidden; box-shadow:var(--shadow-phone); background:var(--surface)}
.adminbar{display:flex; align-items:center; gap:8px; padding:10px 14px; border-bottom:1px solid var(--line); background:var(--surface2)}
.adminbar .dots{display:flex; gap:6px}
.adminbar .dots i{width:11px; height:11px; border-radius:999px; background:var(--line-strong); display:block}
.adminurl{flex:1; max-width:420px; margin:0 auto; background:var(--surface); border:1px solid var(--line); border-radius:999px; padding:5px 14px; font-family:var(--mono); font-size:11px; color:var(--muted); text-align:center}
.adminbody{display:flex; min-height:600px; background:radial-gradient(50% 30% at 50% 0%, var(--glow-teal), transparent 70%), var(--paper)}
.sidebar{width:212px; flex:none; border-right:1px solid var(--line); padding:16px 12px; display:flex; flex-direction:column; gap:3px; background:var(--surface)}
.sidebar .brandrow{display:flex; align-items:center; gap:9px; padding:6px 8px 14px}
.sidebar .si{display:flex; align-items:center; gap:11px; padding:10px 12px; border-radius:10px; color:var(--muted); font-weight:600; font-size:14px; cursor:pointer; text-decoration:none}
.sidebar .si:hover{background:var(--surface2); color:var(--ink)}
.sidebar .si.on{background:var(--brand-soft); color:var(--brand)}
.sidebar .grow{flex:1}
.content{flex:1; padding:24px 28px; overflow:auto}
.content .h1{font-family:"Fraunces",serif; font-weight:600; font-size:26px; letter-spacing:-.02em; margin:0}
.toolbar{display:flex; align-items:center; gap:12px; margin:0 0 20px}
.toolbar .spacer{flex:1}
.dtable{width:100%; border-collapse:collapse; font-size:14px}
.dtable th{text-align:left; font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); font-weight:600; padding:10px 12px; border-bottom:1px solid var(--line)}
.dtable td{padding:13px 12px; border-bottom:1px solid var(--line)}
.dtable tr:last-child td{border-bottom:0}
.dtable tbody tr{cursor:pointer}
.dtable tbody tr:hover td{background:var(--surface2)}
.dgrid{display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:22px}
.dcard{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:16px; box-shadow:var(--shadow)}

/* ---------- device toggle: reframe (same screens, frame restyled - cleaner/cliente) ---------- */
.deskonly{display:none}
body.dev-desk .deskonly{display:flex}
.winshell{display:flex; flex-direction:column; align-items:center}
.winshell .winbody{display:flex; justify-content:center; width:100%}
body.dev-desk .winshell{width:900px; max-width:100%; margin:0 auto; border:1px solid var(--line-strong); border-radius:14px; overflow:hidden; box-shadow:var(--shadow-phone); background:var(--surface)}
body.dev-desk .winshell .winbody{padding:34px 0; background:radial-gradient(50% 30% at 50% 0%, var(--glow-teal), transparent 70%), var(--paper)}

/* ---------- device toggle: stage swap (gestora: phone app vs desktop admin) ---------- */
.stage[data-device]{display:none}
body.dev-phone .stage[data-device="phone"]{display:flex}
body.dev-desk .stage[data-device="desk"]{display:flex}

/* ---------- real map embed (Google Maps iframe) ---------- */
.map.real{padding:0; background:var(--surface2)}
.map iframe{width:100%; height:100%; border:0; display:block}

/* ---------- star rating (NPS / CSAT) ---------- */
.stars{display:flex; gap:8px; justify-content:center; align-items:center}
.stars [data-star]{background:none; border:0; padding:2px; cursor:pointer; color:var(--line-strong); line-height:0}
.stars [data-star] .ico{width:38px; height:38px; fill:none; stroke:currentColor; stroke-width:1.6}
.stars [data-star].on{color:var(--warn)}
.stars [data-star].on .ico{fill:var(--warn); stroke:var(--warn)}

@media (max-width:480px){ body{padding:78px 12px 60px} .frame{width:100%; max-width:360px} }
@media (max-width:1080px){ .adminwin{width:100%} .sidebar{width:172px} }
