:root{
  --primary:#111111;
  --secondary:#c9a24b;
  --bg:#f5f5f7;
  --card:rgba(255,255,255,.82);
  --card-solid:#ffffff;
  --text:#111827;
  --muted:#6b7280;
  --line:rgba(17,24,39,.10);
  --soft:#f7f7f8;
  --ok:#16a34a;
  --warn:#d97706;
  --danger:#dc2626;
  --info:#2563eb;
  --wa:#25d366;
  --radius:24px;
  --radius-sm:16px;
  --shadow:0 22px 70px rgba(15,23,42,.12),0 4px 16px rgba(15,23,42,.05);
  --shadow-sm:0 10px 28px rgba(15,23,42,.08);
  --blur:blur(18px);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text",Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit}img{max-width:100%}
body.public-page{background:linear-gradient(180deg,#f7f7f9 0%,#f1efe9 55%,#f7f7f9 100%)}
.ambient{position:fixed;width:420px;height:420px;border-radius:999px;filter:blur(80px);opacity:.18;pointer-events:none;z-index:-1}.ambient-one{top:70px;left:-150px;background:var(--secondary)}.ambient-two{right:-150px;bottom:80px;background:#6b7280}
.wrap{max-width:760px;margin:0 auto;padding:18px}.client-wrap{max-width:1180px}.panel-wrap{max-width:1180px;padding-top:22px}
.hidden{display:none!important}.center{text-align:center}.muted{color:var(--muted);font-size:.94rem}.row{display:flex;gap:12px}.row>*{flex:1}

/* Public hero premium */
.client-hero{min-height:420px;padding:18px 18px 64px;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.16),transparent 24rem),linear-gradient(135deg,var(--primary),#23211f 58%,#4a3a18);color:#fff;position:relative;overflow:hidden}
.client-hero:before{content:"";position:absolute;inset:auto -15% -42% -15%;height:260px;background:rgba(255,255,255,.08);filter:blur(28px);border-radius:50%}
.client-nav{position:relative;z-index:2;max-width:1180px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:10px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.08);backdrop-filter:var(--blur);border-radius:24px;box-shadow:0 16px 50px rgba(0,0,0,.18)}
.brand-lockup{display:flex;gap:12px;align-items:center}.brand-lockup strong{display:block;font-size:.98rem;letter-spacing:-.02em}.brand-lockup span{display:block;font-size:.78rem;opacity:.72;margin-top:1px}
.logo-fallback,.hero img.logo,.client-nav img.logo{height:48px;width:48px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--secondary),#ffe9a8);color:#111;font-size:1.2rem;font-weight:900;box-shadow:0 10px 24px rgba(0,0,0,.18)}
.hero img.logo,.client-nav img.logo{object-fit:cover;background:#fff;padding:0}.premium-hero-content{position:relative;z-index:1;max-width:760px;margin:54px auto 0;text-align:center}.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.09);border-radius:999px;font-size:.82rem;font-weight:800;color:rgba(255,255,255,.84)}
.client-hero h1{margin:16px 0 10px;font-size:clamp(2.4rem,6vw,4.8rem);line-height:.96;letter-spacing:-.065em}.hero-lead{font-size:clamp(1.05rem,2.4vw,1.35rem);font-weight:600;opacity:.92;margin:.25em auto;max-width:680px}.hero-desc{color:rgba(255,255,255,.72);max-width:620px;margin:8px auto 0}.hero-actions{display:flex;gap:12px;justify-content:center;margin-top:24px;flex-wrap:wrap}.hero-actions .btn{width:auto;min-width:180px}.trust-row{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:22px}.trust-row span{font-size:.82rem;color:rgba(255,255,255,.78);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:7px 12px;font-weight:700;letter-spacing:-.01em}

/* Layout */
.booking-layout{display:grid;grid-template-columns:320px 1fr;gap:18px;align-items:start;margin-top:-70px;position:relative;z-index:4}.booking-main{min-width:0}.sticky-summary{position:sticky;top:18px}.booking-summary{background:rgba(255,255,255,.78);backdrop-filter:var(--blur);border:1px solid rgba(255,255,255,.9);border-radius:28px;box-shadow:var(--shadow);padding:18px}.summary-mini-title{font-weight:900;letter-spacing:-.03em;margin-bottom:12px}.summary-row{display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px solid var(--line)}.summary-row span{color:var(--muted);font-size:.86rem}.summary-row strong{text-align:right;font-size:.9rem}.summary-divider{height:1px;background:var(--line);margin:12px 0}.mini-progress{height:8px;background:#ececef;border-radius:999px;overflow:hidden;margin-top:14px}.mini-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--secondary),#ffd979);border-radius:999px;transition:width .25s ease}
.stepper{display:flex;align-items:center;background:rgba(255,255,255,.72);backdrop-filter:var(--blur);border:1px solid rgba(255,255,255,.9);border-radius:28px;padding:14px 16px;margin-bottom:16px;box-shadow:var(--shadow-sm)}.step-dot{display:flex;align-items:center;gap:8px;color:var(--muted);font-weight:800;white-space:nowrap}.step-dot b{height:30px;width:30px;border-radius:999px;background:#ececef;display:grid;place-items:center;color:#6b7280}.step-dot.active{color:var(--text)}.step-dot.active b{background:var(--primary);color:#fff}.step-dot.done b{background:var(--secondary);color:#111}.step-line{height:2px;background:#e5e7eb;flex:1;margin:0 12px;border-radius:999px}
.card{background:var(--card);backdrop-filter:var(--blur);border:1px solid rgba(255,255,255,.9);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px;margin:14px 0}.premium-card{box-shadow:var(--shadow);border-color:rgba(255,255,255,.95)}.section-title{display:flex;align-items:center;gap:9px;font-size:.78rem;text-transform:uppercase;letter-spacing:.09em;color:var(--muted);margin:24px 4px 10px;font-weight:900}.section-title:before{content:"";width:30px;height:2px;background:linear-gradient(90deg,var(--secondary),transparent);border-radius:999px}.empty,.empty-state{border:1px dashed var(--line);border-radius:var(--radius);padding:24px;background:rgba(255,255,255,.62);color:var(--muted);display:flex;flex-direction:column;gap:4px;text-align:center}.empty strong,.empty-state strong{color:var(--text)}

/* Servicios público */
.serv{width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px;border:1px solid rgba(255,255,255,.92);border-radius:26px;margin:12px 0;cursor:pointer;background:rgba(255,255,255,.76);backdrop-filter:var(--blur);box-shadow:var(--shadow-sm);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease;text-align:left;color:var(--text)}
.serv:hover{transform:translateY(-2px);box-shadow:var(--shadow);background:#fff}.serv.sel{border-color:color-mix(in srgb,var(--secondary) 64%,white);box-shadow:0 0 0 4px color-mix(in srgb,var(--secondary) 22%,transparent),var(--shadow);background:#fff}.serv-left{display:flex;gap:14px;align-items:flex-start}.serv-index{flex:0 0 38px;height:38px;border-radius:14px;background:#f2f2f3;display:grid;place-items:center;font-weight:900;color:var(--secondary)}.serv .nombre{font-weight:900;font-size:1.08rem;letter-spacing:-.02em}.serv .desc{font-size:.92rem;color:var(--muted);margin-top:2px}.serv .dur{font-size:.82rem;color:var(--muted);margin-top:7px}.serv .precio{font-weight:900;color:var(--primary);white-space:nowrap;background:#f8f8f8;border:1px solid var(--line);border-radius:999px;padding:8px 12px}

/* Chips/form/botones */
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.chip{padding:12px 15px;border:1px solid var(--line);border-radius:999px;background:#fff;cursor:pointer;font-size:.95rem;font-weight:800;transition:.16s;color:var(--text);box-shadow:0 5px 14px rgba(15,23,42,.04)}.chip:hover{border-color:var(--secondary);transform:translateY(-1px)}.chip.sel{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 10px 24px rgba(17,17,17,.18)}.chip:disabled{opacity:.4;cursor:not-allowed}
label{display:block;font-size:.86rem;color:var(--muted);margin:13px 0 6px;font-weight:700}input,select,textarea{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:16px;font-size:1rem;background:rgba(255,255,255,.92);color:var(--text);outline:none;transition:border-color .16s,box-shadow .16s,background .16s;font-family:inherit}input:focus,select:focus,textarea:focus{border-color:var(--secondary);box-shadow:0 0 0 4px color-mix(in srgb,var(--secondary) 18%,transparent);background:#fff}textarea{min-height:96px;resize:vertical}input[type="color"]{height:48px;padding:4px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 18px;border:none;border-radius:16px;font-size:1rem;font-weight:900;cursor:pointer;background:var(--primary);color:#fff;width:100%;text-decoration:none;transition:transform .16s ease,opacity .16s ease,box-shadow .16s ease,background .16s}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.btn.sec,.btn.ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.14)}.booking-main .btn.sec,.card .btn.sec{background:#fff;color:var(--text);border:1px solid var(--line)}.btn.wa{background:var(--wa);color:#071b0f}.btn.small{width:auto;padding:9px 13px;font-size:.88rem;border-radius:13px}.btn.danger{background:var(--danger)}.booking-submit{font-size:1.05rem;padding:16px;margin-top:6px}.success-mark{height:54px;width:54px;border-radius:999px;background:#dcfce7;color:#166534;display:grid;place-items:center;margin:0 auto 10px;font-size:1.7rem;font-weight:900}.resumen-box{background:#f8f8f8;border:1px solid var(--line);border-radius:18px;padding:14px;margin:12px 0}.access-link{margin:22px 0}
.msg{padding:13px 14px;border-radius:16px;margin:12px 0;font-size:.95rem;border:1px solid transparent}.msg.ok{background:#dcfce7;color:#166534;border-color:#bbf7d0}.msg.error{background:#fee2e2;color:#991b1b;border-color:#fecaca}.error-text{color:#991b1b}

/* Panel Apple-like */
body:not(.public-page){background:linear-gradient(180deg,#f7f7f9 0,#f1f2f4 100%)}.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:rgba(17,17,17,.92);backdrop-filter:var(--blur);color:#fff;position:sticky;top:0;z-index:20;box-shadow:0 12px 28px rgba(0,0,0,.18)}.topbar strong{letter-spacing:-.03em;font-size:1.02rem}.topbar .btn.small{background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.16)}.tabs{display:flex;gap:4px;overflow-x:auto;background:rgba(255,255,255,.78);border-bottom:1px solid var(--line);position:sticky;top:64px;z-index:19;backdrop-filter:var(--blur);padding:0 10px}.tab{padding:16px 10px;margin:0 2px;border:none;background:none;cursor:pointer;font-size:.94rem;color:var(--muted);white-space:nowrap;border-bottom:3px solid transparent;font-weight:800}.tab.active{color:var(--primary);border-bottom-color:var(--secondary)}.panel-wrap section>.row:first-child{background:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.95);border-radius:24px;padding:14px;box-shadow:var(--shadow-sm)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:14px 0}.stat-card{background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.94);border-radius:20px;padding:15px;box-shadow:var(--shadow-sm)}.stat-card span{display:block;color:var(--muted);font-size:.82rem;font-weight:800}.stat-card strong{font-size:1.65rem;line-height:1.1}.stat-card.warn strong{color:#8a5a00}.stat-card.ok strong{color:#166534}.stat-card.info strong{color:#1e40af}.date-divider{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:22px 0 10px;padding:10px 4px;border-bottom:1px solid var(--line);color:var(--muted);text-transform:capitalize}.date-divider span{font-weight:900;color:var(--text);letter-spacing:-.02em}.date-divider strong{background:#fff;border:1px solid var(--line);border-radius:999px;padding:5px 10px;font-size:.78rem;color:var(--muted)}.turno-card{border:1px solid rgba(255,255,255,.94);border-radius:24px;padding:15px;margin:10px 0;background:rgba(255,255,255,.82);backdrop-filter:var(--blur);box-shadow:var(--shadow-sm)}.turno-card.status-pendiente{border-left:5px solid #f59e0b}.turno-card.status-confirmado{border-left:5px solid var(--ok)}.turno-card.status-realizado{border-left:5px solid var(--info)}.turno-card.status-cancelado{border-left:5px solid var(--danger);opacity:.82}.turno-card .head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.turno-card .acts{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}.turno-main{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:start}.time-pill{min-width:70px;border-radius:18px;background:var(--primary);color:#fff;padding:11px 9px;text-align:center;font-weight:900;letter-spacing:.02em}.time-pill small{display:block;font-size:.68rem;opacity:.75;margin-top:2px}.turno-title{font-weight:900;font-size:1.05rem;letter-spacing:-.02em}.turno-meta{color:var(--muted);font-size:.9rem;margin-top:2px}.turno-note{margin-top:8px;background:#f8f8f8;border:1px solid var(--line);border-radius:14px;padding:9px 11px;color:#4b5563;font-size:.9rem}.badge{display:inline-block;padding:6px 10px;border-radius:999px;font-size:.75rem;font-weight:900;text-transform:capitalize;white-space:nowrap}.badge.pendiente{background:#fff7d6;color:#8a5a00}.badge.confirmado{background:#dcfce7;color:#166534}.badge.cancelado{background:#fee2e2;color:#991b1b}.badge.realizado{background:#dbeafe;color:#1e40af}.hours-row{display:grid;grid-template-columns:150px 1fr 1fr;gap:12px;align-items:center;margin:8px 0}.day-check{margin:0;color:var(--text);font-weight:800}.day-check input{width:auto;margin-right:8px}

/* Calendario panel */
.calendar-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.calendar-title{font-size:1.35rem;font-weight:900;letter-spacing:-.04em}.calendar-actions{display:flex;gap:8px;flex-wrap:wrap}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}.calendar-day{min-height:210px;background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.95);border-radius:24px;box-shadow:var(--shadow-sm);padding:12px;display:flex;flex-direction:column}.calendar-day.today{box-shadow:0 0 0 3px color-mix(in srgb,var(--secondary) 22%,transparent),var(--shadow-sm)}.calendar-day-head{display:flex;justify-content:space-between;gap:8px;align-items:flex-start;margin-bottom:10px}.calendar-day-name{font-weight:900;text-transform:capitalize;letter-spacing:-.02em}.calendar-date-num{height:30px;width:30px;border-radius:999px;background:#f1f2f4;display:grid;place-items:center;font-weight:900}.calendar-day.today .calendar-date-num{background:var(--primary);color:#fff}.calendar-count{font-size:.76rem;color:var(--muted);font-weight:800}.calendar-list{display:flex;flex-direction:column;gap:7px;overflow:auto}.calendar-item{border:1px solid var(--line);border-radius:14px;background:#fff;padding:8px;cursor:pointer;transition:.15s}.calendar-item:hover{transform:translateY(-1px);box-shadow:0 8px 16px rgba(15,23,42,.08)}.calendar-item-time{font-weight:900;font-size:.84rem}.calendar-item-name{font-weight:800;font-size:.82rem;margin-top:2px}.calendar-item-service{color:var(--muted);font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-empty{margin:auto;color:var(--muted);font-size:.82rem;text-align:center}.calendar-item.pendiente{border-left:4px solid #f59e0b}.calendar-item.confirmado{border-left:4px solid var(--ok)}.calendar-item.realizado{border-left:4px solid var(--info)}.calendar-item.cancelado{border-left:4px solid var(--danger);opacity:.75}

/* Modal/tablas */
table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:8px;border-bottom:1px solid var(--line);font-size:.9rem}th{color:var(--muted);font-weight:800}#modal{backdrop-filter:blur(7px)}#modal .card{box-shadow:0 24px 90px rgba(0,0,0,.28)}

@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.serv,.card,.turno-card,.calendar-day{animation:fadeUp .35s ease both}

@media (max-width:980px){.booking-layout{grid-template-columns:1fr;margin-top:-54px}.sticky-summary{position:relative;top:0;order:2}.booking-summary{margin-top:6px}.calendar-grid{grid-template-columns:1fr 1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:720px){.wrap{padding:14px}.client-hero{min-height:390px;padding:14px 14px 58px}.client-nav{border-radius:20px}.brand-lockup span{display:none}.client-hero h1{font-size:2.45rem}.hero-actions .btn{width:100%}.row{flex-direction:column}.stepper{padding:12px}.step-dot span{display:none}.serv{align-items:flex-start;flex-direction:column}.serv .precio{align-self:flex-start}.turno-main{grid-template-columns:1fr}.time-pill{width:max-content}.turno-card .acts .btn{flex:1;min-width:120px}.hours-row{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.calendar-grid{grid-template-columns:1fr}.calendar-toolbar{align-items:flex-start;flex-direction:column}.tabs{top:58px}.topbar{padding:10px 12px}.topbar .row{flex-direction:row}.topbar .btn.small{padding:8px 10px;font-size:.78rem}}

/* ===== Ajustes identidad Ariel + calendario compacto ===== */
.client-nav .brand-lockup img.logo{
  height:58px;width:58px;border-radius:999px;object-fit:cover;background:#fff;padding:3px;
  box-shadow:0 14px 34px rgba(0,0,0,.22);
}
.client-hero-logo{
  display:block;width:min(188px,46vw);aspect-ratio:1/1;object-fit:cover;border-radius:999px;margin:0 auto 18px;
  background:#fff;padding:10px;box-shadow:0 24px 70px rgba(0,0,0,.22),0 0 0 1px rgba(255,255,255,.38);
}
.panel-brand{display:flex;align-items:center;gap:12px;min-width:0}
.panel-brand img{height:44px;width:44px;border-radius:999px;object-fit:cover;background:#fff;padding:2px;box-shadow:0 8px 22px rgba(0,0,0,.24)}
.panel-brand strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.panel-login-hero{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:34px 18px!important}
.panel-login-logo{width:122px;height:122px;border-radius:999px;object-fit:cover;background:#fff;padding:7px;margin-bottom:14px;box-shadow:0 18px 50px rgba(0,0,0,.24)}
.client-social-card{margin-top:16px;border-radius:22px;padding:15px;background:linear-gradient(135deg,#fff,#f6f1e6);border:1px solid rgba(201,162,75,.32);box-shadow:0 10px 30px rgba(15,23,42,.07)}
.client-social-card span{display:block;color:var(--muted);font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em}.client-social-card strong{display:block;margin:4px 0 10px;font-size:1rem;letter-spacing:-.02em}.client-social-card a{display:inline-flex;font-weight:900;text-decoration:none;color:var(--primary);border-bottom:1px solid var(--secondary)}
.client-social-footer{margin:20px 0 0;padding:15px;border-radius:22px;background:rgba(255,255,255,.68);border:1px solid rgba(255,255,255,.9);box-shadow:var(--shadow-sm)}
.client-social-footer span{display:block;color:var(--muted);font-size:.86rem;margin-bottom:4px}.client-social-footer a{font-weight:900;color:var(--primary);text-decoration:none;border-bottom:2px solid var(--secondary)}
.compact-week-nav{display:inline-flex!important;align-items:center;gap:8px;padding:7px;background:rgba(255,255,255,.72);border:1px solid rgba(255,255,255,.95);border-radius:999px;box-shadow:var(--shadow-sm);backdrop-filter:var(--blur)}
.week-arrow{height:44px;width:44px;border:0;border-radius:999px;background:#fff;color:var(--primary);font-size:1.9rem;line-height:1;font-weight:900;display:grid;place-items:center;cursor:pointer;box-shadow:0 6px 18px rgba(15,23,42,.08);transition:.16s ease}
.week-arrow:hover{transform:translateY(-1px) scale(1.03);background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}
.calendar-today{min-width:82px;border-radius:999px!important;height:44px;padding:0 18px!important;background:var(--primary)!important;color:#fff!important;box-shadow:0 8px 20px rgba(17,17,17,.18)}
@media (max-width:720px){.client-hero-logo{width:132px;padding:7px}.client-nav .brand-lockup img.logo{height:48px;width:48px}.panel-brand img{height:38px;width:38px}.compact-week-nav{width:100%;justify-content:center}.week-arrow{height:42px;width:42px}.calendar-today{height:42px}}


/* ===== Progreso vivo + promoción Web Make Studio ===== */
.summary-status{font-weight:700;line-height:1.45;margin:14px 0 0;color:#4b5563}
.mini-progress-wrap{margin-top:14px}
.mini-progress{height:10px;background:#ececef;border-radius:999px;overflow:hidden;position:relative;box-shadow:inset 0 1px 2px rgba(0,0,0,.05)}
.mini-progress:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);transform:translateX(-100%);animation:progressShine 2.4s ease-in-out infinite}
.mini-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--secondary),#ffe08a,#f3c35b);border-radius:999px;transition:width .35s cubic-bezier(.2,.8,.2,1);box-shadow:0 0 18px color-mix(in srgb,var(--secondary) 45%,transparent)}
.mini-progress-label{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:8px;color:var(--muted);font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em}
.mini-progress-label strong{color:var(--primary);font-size:.88rem;letter-spacing:-.02em;text-transform:none}
.summary-row strong{transition:color .2s ease,transform .2s ease}.summary-row strong.summary-pop{color:var(--primary);animation:summaryPop .28s ease both}
.step-dot.done{color:var(--text)}.step-dot.done b{background:linear-gradient(135deg,var(--secondary),#ffe08a);color:#111;box-shadow:0 8px 18px rgba(201,162,75,.22)}
.step-dot.active b{box-shadow:0 8px 20px rgba(17,17,17,.22)}
.webmake-card{margin-top:16px;border-radius:22px;padding:15px;background:linear-gradient(145deg,#111827,#1f2937);color:#fff;border:1px solid rgba(255,255,255,.12);box-shadow:0 18px 46px rgba(15,23,42,.18);overflow:hidden;position:relative}
.webmake-card:before{content:"";position:absolute;right:-44px;top:-44px;width:120px;height:120px;border-radius:999px;background:rgba(201,162,75,.28);filter:blur(8px)}
.webmake-card span{display:block;color:rgba(255,255,255,.64);font-size:.74rem;font-weight:900;text-transform:uppercase;letter-spacing:.09em;position:relative}.webmake-card strong{display:block;font-size:1.08rem;margin:4px 0 4px;letter-spacing:-.03em;position:relative}.webmake-card p{margin:0 0 10px;color:rgba(255,255,255,.72);font-size:.86rem;position:relative}.webmake-card a{display:inline-flex;color:#fff;font-weight:900;text-decoration:none;border-bottom:1px solid var(--secondary);position:relative}
@keyframes summaryPop{0%{transform:translateY(2px);opacity:.78}100%{transform:translateY(0);opacity:1}}
@keyframes progressShine{0%,45%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

.webmake-footer-card{grid-column:1/-1;justify-self:start;margin:8px 0 4px;max-width:360px;border-radius:22px;padding:16px 18px;background:linear-gradient(145deg,#111827,#1f2937);color:#fff;border:1px solid rgba(255,255,255,.12);box-shadow:0 18px 46px rgba(15,23,42,.16);overflow:hidden;position:relative}
.webmake-footer-card:before{content:"";position:absolute;right:-44px;top:-44px;width:120px;height:120px;border-radius:999px;background:rgba(201,162,75,.26);filter:blur(8px)}
.webmake-footer-card span{display:block;color:rgba(255,255,255,.64);font-size:.72rem;font-weight:900;text-transform:uppercase;letter-spacing:.09em;position:relative}
.webmake-footer-card strong{display:block;font-size:1.1rem;margin:5px 0 4px;letter-spacing:-.03em;position:relative}
.webmake-footer-card p{margin:0 0 10px;color:rgba(255,255,255,.72);font-size:.88rem;position:relative}
.webmake-footer-card a{display:inline-flex;color:#fff;font-weight:900;text-decoration:none;border-bottom:1px solid var(--secondary);position:relative}
@media (max-width:980px){.webmake-footer-card{justify-self:stretch;max-width:none;margin-top:10px}}


/* ===== Optimización mobile solicitada: logo, pasos y fechas del panel ===== */
.client-nav .brand-lockup img.logo{
  width:86px;
  height:56px;
  border-radius:18px;
  object-fit:contain;
  object-position:center;
  padding:5px;
  background:#fff;
}
.client-nav .brand-lockup #logo-box{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
}
.client-hero-logo{
  object-fit:contain;
  object-position:center;
}
.step-dot span{
  max-width:110px;
  line-height:1.05;
  white-space:normal;
}

@media (max-width:720px){
  .client-nav{
    align-items:center;
    gap:10px;
    padding:9px;
  }
  .brand-lockup{
    min-width:0;
    gap:9px;
  }
  .client-nav .brand-lockup img.logo{
    width:74px;
    height:48px;
    border-radius:16px;
    padding:5px;
    object-fit:contain;
  }
  .brand-lockup strong{
    font-size:.9rem;
    line-height:1.05;
  }
  .client-nav .btn{
    padding:10px 12px;
    font-size:.82rem;
  }
  .client-hero-logo{
    width:148px;
    padding:8px;
    object-fit:contain;
  }

  .stepper{
    gap:7px;
    padding:11px 10px;
    border-radius:22px;
    align-items:flex-start;
  }
  .step-dot{
    flex:0 0 28%;
    flex-direction:column;
    align-items:center;
    justify-content:flex-start;
    gap:6px;
    text-align:center;
    white-space:normal;
    font-size:.72rem;
    line-height:1.05;
  }
  .step-dot span{
    display:block;
    max-width:78px;
    line-height:1.08;
  }
  .step-dot b{
    height:28px;
    width:28px;
    font-size:.78rem;
  }
  .step-line{
    margin:14px -4px 0;
    min-width:16px;
  }

  .date-divider{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    justify-content:flex-start;
    gap:7px;
    margin:18px 0 9px;
    padding:12px 14px;
    border:1px solid var(--line);
    border-radius:18px;
    background:rgba(255,255,255,.78);
    box-shadow:0 8px 22px rgba(15,23,42,.06);
  }
  .date-divider span{
    font-size:.98rem;
    line-height:1.2;
    width:100%;
  }
  .date-divider strong{
    align-self:flex-start;
    margin:0;
  }
}

/* ===== Ajustes finales solicitados: logo mobile, pasos 3/3 y botones del panel ===== */
.client-nav .brand-lockup #logo-box{
  width:64px;
  height:64px;
  flex:0 0 64px;
  display:grid;
  place-items:center;
  overflow:hidden;
  border-radius:20px;
  background:#fff;
  box-shadow:0 14px 34px rgba(0,0,0,.22);
}
.client-nav .brand-lockup img.logo{
  width:100%!important;
  height:100%!important;
  display:block;
  border-radius:18px!important;
  object-fit:contain!important;
  object-position:center!important;
  padding:5px!important;
  background:#fff!important;
  box-shadow:none!important;
}
.client-hero-logo{
  width:clamp(144px,26vw,188px)!important;
  height:clamp(144px,26vw,188px)!important;
  aspect-ratio:1/1;
  object-fit:contain!important;
  object-position:center!important;
  border-radius:30px!important;
  padding:10px!important;
  background:#fff!important;
}

.stepper{
  display:grid;
  grid-template-columns:max-content minmax(34px,1fr) max-content minmax(34px,1fr) max-content;
  align-items:start;
  gap:10px;
}
.step-dot{
  min-width:0;
  justify-content:center;
  text-align:center;
}
.step-dot span{
  display:block!important;
  max-width:none;
  line-height:1.12;
  white-space:normal;
}
.step-line{
  width:100%;
  min-width:34px;
  height:4px;
  margin:14px 0 0!important;
  border-radius:999px;
  background:#e5e7eb;
  overflow:hidden;
  position:relative;
}
.step-line:after{
  content:"";
  position:absolute;
  inset:0;
  width:0;
  background:linear-gradient(90deg,var(--secondary),#ffe08a);
  border-radius:999px;
  transition:width .35s cubic-bezier(.2,.8,.2,1);
}
.step-line.done:after{width:100%}
.step-dot.done.active b{
  background:linear-gradient(135deg,var(--secondary),#ffe08a)!important;
  color:#111!important;
}

.panel-wrap .turno-card .acts .btn.sec,
.turno-card .acts .btn.sec,
.panel-wrap .btn.sec{
  background:#fff!important;
  color:var(--text)!important;
  border:1px solid var(--line)!important;
}
.panel-wrap .turno-card .acts .btn.sec:hover,
.turno-card .acts .btn.sec:hover{
  background:#f8f8f8!important;
  box-shadow:0 8px 18px rgba(15,23,42,.08);
}
.turno-card .acts .btn[data-a="editar"]{
  background:#111827!important;
  color:#fff!important;
  border:1px solid #111827!important;
}
.turno-card .acts .btn[data-a="cancelado"]{
  background:#fff7ed!important;
  color:#9a3412!important;
  border:1px solid #fed7aa!important;
}

@media (max-width:720px){
  .client-hero{padding-top:12px!important;}
  .client-nav{
    display:flex;
    align-items:center;
    gap:10px;
  }
  .client-nav .brand-lockup #logo-box{
    width:58px;
    height:58px;
    flex-basis:58px;
    border-radius:18px;
  }
  .client-nav .brand-lockup img.logo{
    border-radius:16px!important;
    padding:4px!important;
  }
  .client-hero-logo{
    width:150px!important;
    height:150px!important;
    border-radius:28px!important;
    padding:9px!important;
    margin-bottom:16px!important;
  }
  .stepper{
    grid-template-columns:1fr 22px 1fr 22px 1fr;
    gap:6px;
    padding:12px 10px!important;
    border-radius:22px;
  }
  .step-dot{
    flex-direction:column;
    align-items:center;
    gap:6px;
    font-size:.72rem;
    line-height:1.08;
    white-space:normal;
  }
  .step-dot span{
    display:block!important;
    max-width:86px!important;
    min-height:24px;
  }
  .step-dot b{
    width:30px!important;
    height:30px!important;
    font-size:.8rem;
  }
  .step-line{
    min-width:0;
    width:100%;
    height:4px;
    margin-top:15px!important;
  }
  .turno-card .acts{
    display:grid!important;
    grid-template-columns:1fr 1fr;
    gap:8px!important;
  }
  .turno-card .acts .btn{
    min-width:0!important;
    width:100%!important;
    flex:none!important;
    padding:10px 9px!important;
    font-size:.8rem!important;
  }
}
