
:root{
  --rose:#E56AA6;
  --rose-dark:#C94B8B;
  --rose-deep:#862B63;
  --blush:#FFE8F3;
  --blush-2:#FFF6FB;
  --violet:#9B5CF6;
  --violet-soft:#F1E8FF;
  --sage:#EFDABF;
  --sage-dark:#C7A986;
  --mint:#FFF0F7;
  --cream:#FFF9FC;
  --paper:#FFFFFF;
  --ink:#4A2340;
  --muted:#8A6A7F;
  --gold:#E0B86E;
  --line:rgba(190,84,139,.10);
  --shadow:0 24px 70px rgba(201,75,139,.16);
  --shadow-soft:0 14px 40px rgba(201,75,139,.10);
  --radius-xl:36px;
  --radius-lg:26px;
  --radius-md:19px;
  --safe-bottom:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:100px}
body{margin:0;background:var(--cream);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;line-height:1.6}
body.modal-open{overflow:hidden}
button,input,textarea{font:inherit}
button{cursor:pointer}
button:disabled{cursor:not-allowed}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
[hidden]{display:none!important}
.ui-icon{width:21px;height:21px;display:inline-block;flex:none}
.container-shell{width:min(1180px,calc(100% - 40px));margin-inline:auto}
.bg-cream{background:var(--cream)}
.text-ink{color:var(--ink)}
.site-noise{position:fixed;inset:0;pointer-events:none;opacity:.035;z-index:999;background-image:url("../img/pattern.svg");background-size:180px}
.eyebrow{margin:0 0 10px;color:var(--rose-dark);font-size:.78rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase}
h1,h2,h3,p{margin-top:0}
h1,h2{font-family:Georgia,"Times New Roman",serif;font-weight:500;line-height:1.05;letter-spacing:-.025em}
h1 em,h2 em{color:var(--rose-dark);font-weight:500}
.section-space{padding:110px 0}
.button{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:12px 20px;border:1px solid transparent;border-radius:999px;font-size:.94rem;font-weight:800;transition:.25s ease;white-space:nowrap}
.button:hover{transform:translateY(-2px)}
.button:active{transform:translateY(0)}
.button-primary{background:linear-gradient(135deg,var(--rose),var(--rose-dark));color:white;box-shadow:0 14px 30px rgba(135,68,91,.23)}
.button-primary:hover{box-shadow:0 18px 38px rgba(135,68,91,.3)}
.button-primary:disabled{opacity:.45;box-shadow:none;transform:none}
.button-soft{background:var(--blush);color:var(--rose-dark);border-color:rgba(135,68,91,.09)}
.button-violet{background:linear-gradient(135deg,var(--violet),#62466d);color:#fff;box-shadow:0 14px 30px rgba(118,88,127,.2)}
.button-light{background:#fff;color:var(--rose-dark);box-shadow:0 14px 36px rgba(65,36,47,.12)}
.button-ghost{background:transparent;color:var(--muted);border-color:var(--line)}
.button-whatsapp{background:#25D366;color:#073b1d;box-shadow:0 14px 30px rgba(37,211,102,.22)}
.button-large{min-height:56px;padding:15px 25px;font-size:1rem}
.button-full{width:100%}
.text-link{display:inline-flex;align-items:center;gap:7px;color:var(--rose-dark);font-weight:800}
.text-link .ui-icon{width:18px}
.icon-button{width:46px;height:46px;border:1px solid var(--line);background:rgba(255,255,255,.78);color:var(--rose-dark);display:inline-flex;align-items:center;justify-content:center;border-radius:15px;transition:.22s ease}
.icon-button:hover{transform:translateY(-2px);background:#fff;box-shadow:var(--shadow-soft)}
.icon-button.danger{color:#a84f5e;background:#fff1f3}

/* Header */
.site-header{position:sticky;top:0;z-index:80;background:rgba(255,249,252,.96);border-bottom:1px solid rgba(201,75,139,.12);backdrop-filter:blur(18px)}
.header-inner{min-height:86px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand-link{display:block;flex:none}
.brand-logo{width:255px;height:78px;object-fit:contain;object-position:left center}
.desktop-nav{display:flex;align-items:center;gap:30px;color:#675961;font-size:.93rem;font-weight:700}
.desktop-nav a{position:relative;padding:12px 0}
.desktop-nav a::after{content:"";position:absolute;left:0;right:100%;bottom:5px;height:2px;border-radius:2px;background:var(--rose);transition:.25s}
.desktop-nav a:hover::after{right:0}
.header-actions{display:flex;align-items:center;gap:10px}
.mobile-menu-button{display:none}
.mobile-menu{padding:10px 20px 20px;background:var(--cream);border-top:1px solid var(--line)}
.mobile-menu a{display:block;padding:13px 8px;border-bottom:1px solid var(--line);font-weight:750}

/* Hero */
.hero-section{position:relative;overflow:hidden;padding:76px 0 84px;background: radial-gradient(circle at 15% 12%, rgba(241,221,226,.95), transparent 26%), radial-gradient(circle at 88% 84%, rgba(236,243,238,.95), transparent 28%), linear-gradient(180deg,#fffdfd 0%, #fff8fa 58%, #fffdfc 100%)}
.hero-grid{display:grid;grid-template-columns:1.03fr .97fr;align-items:center;gap:64px}
.hero-copy{position:relative;z-index:2}
.status-pill{width:max-content;max-width:100%;display:flex;align-items:center;gap:12px;padding:10px 15px 10px 12px;border-radius:18px;background:rgba(255,255,255,.78);border:1px solid var(--line);box-shadow:var(--shadow-soft);margin-bottom:28px}
.status-pill .status-dot,.sidebar-status .status-dot,.today-toggle-card .status-dot{width:11px;height:11px;border-radius:99px;flex:none;background:var(--sage);box-shadow:0 0 0 5px rgba(152,180,160,.16)}
.status-pill.is-closed .status-dot,.sidebar-status.is-closed .status-dot,.today-toggle-card.is-closed .status-dot{background:var(--rose);box-shadow:0 0 0 5px rgba(199,121,145,.16)}
.status-pill span:last-child{display:flex;flex-direction:column}
.status-pill strong{font-size:.88rem}
.status-pill small{font-size:.75rem;color:var(--muted)}
.hero-copy h1{font-size:clamp(3.4rem,6vw,6.5rem);margin:0 0 25px;max-width:760px}
.hero-lead{font-size:1.12rem;color:var(--muted);max-width:650px;margin-bottom:31px}
.hero-buttons{display:flex;flex-wrap:wrap;gap:12px}
.trust-row{display:flex;flex-wrap:wrap;gap:28px;margin-top:34px}
.trust-item{display:flex;align-items:center;gap:11px}
.trust-icon{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;background:var(--blush);color:var(--rose-dark)}
.trust-item>span:last-child{display:flex;flex-direction:column}
.trust-item strong{font-size:.86rem}
.trust-item small{color:var(--muted);font-size:.75rem}
.hero-art{position:relative;padding:30px}
.hero-art-card{position:relative;border:1px solid rgba(255,255,255,.92);border-radius:58px;padding:18px;background:linear-gradient(145deg,rgba(255,255,255,.88),rgba(255,255,255,.62));box-shadow:0 30px 80px rgba(112,76,89,.13);backdrop-filter:blur(10px);transform:rotate(1deg)}
.hero-art-card img{width:100%;border-radius:43px;background:#fff}
.floating-card{position:absolute;z-index:4;display:flex;align-items:center;gap:11px;padding:13px 16px;border:1px solid rgba(255,255,255,.8);background:rgba(255,255,255,.88);backdrop-filter:blur(14px);border-radius:18px;box-shadow:0 18px 40px rgba(88,48,63,.15);animation:floatCard 4.5s ease-in-out infinite}
.floating-card-top{right:-10px;top:84px}
.floating-card-bottom{left:-9px;bottom:66px;animation-delay:-1.6s}
.floating-card strong,.floating-card small{display:block}
.floating-card strong{font-size:.83rem}
.floating-card small{font-size:.72rem;color:var(--muted)}
.mini-icon{width:38px;height:38px;border-radius:13px;background:var(--blush);color:var(--rose-dark);display:grid;place-items:center}
.mini-icon.mint{background:var(--mint);color:var(--sage-dark)}
.decorative-orb{position:absolute;border-radius:50%;filter:blur(1px);pointer-events:none}
.orb-one{width:160px;height:160px;left:-80px;top:220px;background:rgba(238,231,244,.75)}
.orb-two{width:120px;height:120px;right:-55px;bottom:40px;background:rgba(248,231,236,.8)}
@keyframes floatCard{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-10px) rotate(1deg)}}

/* Marquee */
.marquee-strip{overflow:hidden;background:linear-gradient(90deg,#d858a2,#9c57f6);color:#fff;padding:17px 0}
.marquee-track{display:flex;align-items:center;gap:30px;width:max-content;animation:marquee 24s linear infinite;font-family:Georgia,serif;font-size:1.05rem;letter-spacing:.04em}
.marquee-track i{color:#e8c893;font-style:normal}
@keyframes marquee{to{transform:translateX(-50%)}}

/* Headings and services */
.section-heading{display:flex;align-items:end;justify-content:space-between;gap:30px;margin-bottom:42px}
.section-heading h2,.experience-copy h2,.booking-intro h2,.final-cta-card h2{font-size:clamp(2.5rem,4vw,4.2rem);margin:0;max-width:780px}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.service-card{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius-lg);background:#fff;box-shadow:var(--shadow-soft);transition:.3s ease}
.service-card:hover{transform:translateY(-7px);box-shadow:var(--shadow)}
.service-number{position:absolute;top:18px;left:20px;z-index:3;color:rgba(61,43,51,.35);font-size:.76rem;font-weight:850;letter-spacing:.15em}
.service-illustration{height:210px;position:relative;overflow:hidden;background:linear-gradient(145deg,var(--blush),var(--violet-soft))}
.service-illustration-2{background:linear-gradient(145deg,var(--mint),#f7f1e9)}
.service-illustration-3{background:linear-gradient(145deg,#f7edf2,var(--mint))}
.nail-shape{position:absolute;width:76px;height:155px;border-radius:38px 38px 26px 26px;left:50%;top:37px;transform:translateX(-50%) rotate(8deg);background:linear-gradient(180deg,#f5c8ce,#d998aa);box-shadow:inset 0 0 0 6px rgba(255,255,255,.45),0 18px 30px rgba(91,51,66,.12)}
.polish-shape{position:absolute;width:50px;height:74px;border-radius:13px;right:44px;bottom:24px;background:var(--violet);transform:rotate(-10deg)}
.polish-shape::before{content:"";position:absolute;width:30px;height:34px;left:10px;top:-27px;border-radius:8px 8px 3px 3px;background:var(--ink)}
.spark-shape{position:absolute;left:43px;top:57px;color:var(--gold);font-size:2.5rem}
.service-illustration-2 .nail-shape{background:linear-gradient(180deg,#d9eadf,#9abca6)}
.service-illustration-2 .polish-shape{background:var(--rose)}
.service-illustration-3 .nail-shape{background:linear-gradient(180deg,#e8d9ed,#ae91b8)}
.service-illustration-3 .polish-shape{background:var(--sage-dark)}
.service-card-body{padding:25px}
.service-card h3{font-family:Georgia,serif;font-size:1.55rem;margin:0 0 10px}
.service-card p{color:var(--muted);font-size:.91rem;min-height:70px;margin-bottom:20px}
.service-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid var(--line);padding-top:18px}
.service-meta>span{display:flex;align-items:center;gap:7px;color:var(--muted);font-size:.78rem;font-weight:700}
.service-meta .ui-icon{width:17px}
.round-arrow{width:41px;height:41px;border:0;border-radius:14px;display:grid;place-items:center;background:var(--blush);color:var(--rose-dark);transition:.25s}
.round-arrow:hover{background:var(--rose-dark);color:#fff;transform:rotate(-8deg)}
.setup-alert{display:flex;flex-direction:column;gap:5px;border:1px solid rgba(175,83,99,.2);background:#fff1f3;color:#743846;padding:20px;border-radius:18px}
.empty-state,.inline-empty{padding:28px;border:1px dashed var(--line);border-radius:18px;color:var(--muted);text-align:center}

/* Experience */
.experience-section{background:linear-gradient(135deg,#fffdfd,var(--blush-2))}
.experience-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:70px;align-items:center}
.experience-visual{min-height:540px}
.abstract-nails{height:540px;position:relative;overflow:hidden;border-radius:60px;background:
 radial-gradient(circle at 30% 25%,rgba(255,255,255,.85),transparent 30%),
 linear-gradient(145deg,var(--violet-soft),var(--blush),var(--mint));box-shadow:var(--shadow)}
.abstract-hand{position:absolute;width:350px;height:260px;left:80px;top:160px;border-radius:55% 45% 55% 35%;background:#f2c7c8;transform:rotate(-12deg);box-shadow:0 24px 45px rgba(92,50,66,.13)}
.abstract-hand span{position:absolute;width:60px;height:170px;border-radius:30px 30px 24px 24px;background:#f2c7c8;top:-105px;box-shadow:inset 0 0 0 5px rgba(255,255,255,.17)}
.abstract-hand span::after{content:"";position:absolute;left:11px;right:11px;top:8px;height:55px;border-radius:25px 25px 15px 15px;background:linear-gradient(180deg,#c8869e,#a35d76);box-shadow:inset 0 0 0 3px rgba(255,255,255,.5)}
.abstract-hand span:nth-child(1){left:35px;height:145px;transform:rotate(-9deg)}
.abstract-hand span:nth-child(2){left:105px;height:185px;top:-128px;transform:rotate(-3deg)}
.abstract-hand span:nth-child(3){left:178px;height:178px;top:-118px;transform:rotate(4deg)}
.abstract-hand span:nth-child(4){left:248px;height:148px;top:-91px;transform:rotate(11deg)}
.abstract-polish{position:absolute;width:95px;height:132px;right:72px;bottom:56px;border-radius:25px;background:linear-gradient(145deg,var(--rose),var(--rose-deep));transform:rotate(7deg);box-shadow:0 18px 35px rgba(100,52,70,.2)}
.abstract-polish::before{content:"";position:absolute;left:22px;top:-78px;width:51px;height:83px;border-radius:14px 14px 5px 5px;background:var(--ink)}
.abstract-leaf{position:absolute;width:130px;height:55px;border-radius:100% 0 100% 0;background:rgba(102,131,115,.32)}
.leaf-a{left:28px;bottom:45px;transform:rotate(25deg)}
.leaf-b{right:35px;top:45px;transform:rotate(-30deg)}
.abstract-star{position:absolute;right:90px;top:150px;color:var(--gold);font-size:3rem}
.experience-copy>p:not(.eyebrow){color:var(--muted);font-size:1.05rem;max-width:620px}
.benefit-list{display:grid;gap:14px;margin:27px 0}
.benefit-item{display:flex;gap:13px;align-items:flex-start;padding:16px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.75)}
.benefit-item>span{width:34px;height:34px;display:grid;place-items:center;border-radius:12px;background:var(--mint);color:var(--sage-dark);flex:none}
.benefit-item strong,.benefit-item small{display:block}
.benefit-item small{color:var(--muted);margin-top:2px}

/* Booking */
.booking-section{background:
 linear-gradient(rgba(255,249,246,.94),rgba(255,249,246,.94)),
 url("../img/pattern.svg");background-size:auto,180px}
.booking-shell{display:grid;grid-template-columns:.72fr 1.28fr;gap:34px;border:1px solid var(--line);border-radius:42px;background:#fff;box-shadow:var(--shadow);padding:28px}
.booking-intro{padding:38px 28px;border-radius:31px;background:linear-gradient(155deg,var(--blush),var(--violet-soft));display:flex;flex-direction:column}
.booking-intro h2{font-size:clamp(2.4rem,3.4vw,3.6rem)}
.booking-intro>p:not(.eyebrow){color:var(--muted)}
.booking-note{display:flex;gap:12px;padding:16px;border:1px solid rgba(135,68,91,.11);border-radius:17px;background:rgba(255,255,255,.62);font-size:.86rem;margin-top:16px}
.booking-note .ui-icon{color:var(--rose-dark)}
.booking-contact{margin-top:auto;padding-top:30px;display:flex;flex-direction:column;gap:7px;font-size:.86rem}
.booking-contact>a{display:inline-flex;align-items:center;gap:7px;color:var(--sage-dark);font-weight:850}
.booking-wizard{padding:26px}
.wizard-progress{display:flex;align-items:center;justify-content:space-between;margin-bottom:33px}
.wizard-progress>i{height:1px;background:var(--line);flex:1;margin:0 7px}
.progress-step{border:0;background:transparent;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:5px;padding:0}
.progress-step span{width:33px;height:33px;border-radius:50%;display:grid;place-items:center;background:#f6f2f3;font-size:.75rem;font-weight:850;transition:.25s}
.progress-step small{font-size:.68rem;font-weight:750}
.progress-step.is-active span,.progress-step.is-complete span{background:var(--rose-dark);color:#fff}
.progress-step.is-active small{color:var(--rose-dark)}
.wizard-step{animation:stepIn .32s ease both}
@keyframes stepIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.wizard-title{display:flex;align-items:flex-start;gap:14px;margin-bottom:22px}
.wizard-title>span{font-family:Georgia,serif;color:var(--rose);font-size:1.2rem}
.wizard-title h3{font-family:Georgia,serif;font-size:1.65rem;margin:0 0 2px}
.wizard-title p{margin:0;color:var(--muted);font-size:.84rem}
.booking-services{display:grid;gap:10px;margin-bottom:21px}
.booking-service-option{display:flex;align-items:center;gap:13px;width:100%;padding:14px;border:1px solid var(--line);border-radius:17px;background:#fff;text-align:left;transition:.2s}
.booking-service-option:hover{border-color:rgba(135,68,91,.3);transform:translateX(3px)}
.booking-service-option.is-selected{background:var(--blush-2);border-color:var(--rose);box-shadow:0 8px 24px rgba(135,68,91,.09)}
.booking-service-icon{width:43px;height:43px;border-radius:14px;background:var(--blush);color:var(--rose-dark);display:grid;place-items:center}
.booking-service-text{flex:1}
.booking-service-text strong,.booking-service-text small{display:block}
.booking-service-text small{color:var(--muted);font-size:.75rem}
.booking-service-check{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;background:#f6f2f3;color:transparent}
.booking-service-option.is-selected .booking-service-check{background:var(--rose-dark);color:#fff}
.booking-service-check .ui-icon{width:16px}
.wizard-next{margin-left:auto}
.custom-calendar{border:1px solid var(--line);border-radius:21px;padding:18px;background:#fff}
.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:15px}
.calendar-header strong{font-family:Georgia,serif;font-size:1.18rem}
.calendar-nav{width:36px;height:36px;border:0;border-radius:12px;background:var(--blush);color:var(--rose-dark);font-size:1.4rem;display:grid;place-items:center}
.calendar-nav:disabled{opacity:.35}
.calendar-weekdays,.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.calendar-weekdays{margin-bottom:6px}
.calendar-weekdays span{text-align:center;color:var(--muted);font-size:.68rem;font-weight:800}
.calendar-day{aspect-ratio:1;border:0;border-radius:12px;background:transparent;color:var(--ink);font-size:.84rem;font-weight:700;position:relative;transition:.2s}
.calendar-day:hover:not(:disabled){background:var(--blush)}
.calendar-day:disabled{color:#d5cdd0}
.calendar-day.is-today::after{content:"";position:absolute;bottom:5px;left:50%;width:4px;height:4px;border-radius:50%;background:var(--rose);transform:translateX(-50%)}
.calendar-day.is-selected{background:var(--rose-dark)!important;color:#fff}
.calendar-day.is-loading{color:transparent}
.calendar-day.is-loading::before{content:"";position:absolute;width:16px;height:16px;border:2px solid rgba(135,68,91,.2);border-top-color:var(--rose-dark);border-radius:50%;animation:spin .7s linear infinite}
.calendar-blank{aspect-ratio:1}
.wizard-actions{display:flex;justify-content:space-between;gap:12px;margin-top:22px}
.time-slots{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;min-height:116px}
.time-slot{padding:13px 8px;border:1px solid var(--line);background:#fff;border-radius:14px;color:var(--ink);font-weight:800;font-size:.85rem;transition:.2s}
.time-slot:hover{border-color:var(--rose);background:var(--blush-2)}
.time-slot.is-selected{background:var(--rose-dark);border-color:var(--rose-dark);color:#fff}
.slots-empty{grid-column:1/-1;display:grid;place-items:center;min-height:100px;border:1px dashed var(--line);border-radius:16px;color:var(--muted);font-size:.85rem}
.slots-loader{display:flex;gap:7px;justify-content:center;padding:35px}
.slots-loader span{width:9px;height:9px;border-radius:50%;background:var(--rose);animation:pulseDot .9s infinite alternate}
.slots-loader span:nth-child(2){animation-delay:.15s}.slots-loader span:nth-child(3){animation-delay:.3s}
@keyframes pulseDot{to{transform:translateY(-8px);opacity:.4}}
.field-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}
.field>span{font-size:.77rem;font-weight:800;color:#5e5056}
.field>span small{color:var(--muted);font-weight:600}
.field input,.field textarea{width:100%;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:15px;padding:13px 14px;outline:0;transition:.2s;resize:vertical}
.field input:focus,.field textarea:focus{border-color:var(--rose);box-shadow:0 0 0 4px rgba(199,121,145,.1)}
.field.is-invalid input,.field.is-invalid textarea{border-color:#c55769;box-shadow:0 0 0 4px rgba(197,87,105,.1)}
.reservation-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;background:var(--blush-2);padding:13px;border-radius:16px;margin-top:6px}
.reservation-summary div,.success-details div{display:flex;flex-direction:column}
.reservation-summary span,.success-details span{font-size:.67rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.reservation-summary strong,.success-details strong{font-size:.82rem}
.wizard-alert{padding:13px 15px;border-radius:14px;margin-bottom:15px;font-size:.84rem;font-weight:700}
.wizard-alert.is-error{background:#fff0f2;color:#923e50;border:1px solid rgba(146,62,80,.13)}
.wizard-alert.is-soft{background:var(--violet-soft);color:var(--violet);border:1px solid rgba(118,88,127,.13)}
.success-step{text-align:center;padding:22px 8px}
.success-icon{width:75px;height:75px;border-radius:50%;display:grid;place-items:center;margin:0 auto 18px;background:var(--mint);color:var(--sage-dark);box-shadow:0 0 0 12px rgba(231,242,234,.6)}
.success-icon .ui-icon{width:34px;height:34px}
.success-step h3{font-family:Georgia,serif;font-size:2.15rem;margin:0 0 10px}
.success-step>p:not(.eyebrow){color:var(--muted)}
.success-code{display:flex;flex-direction:column;gap:3px;width:max-content;margin:20px auto;padding:13px 24px;border:1px dashed var(--rose);border-radius:15px;background:var(--blush-2)}
.success-code span{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.success-code strong{font-size:1.3rem;color:var(--rose-dark)}
.success-details{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin:0 auto 20px;max-width:560px}
.success-details div{padding:11px;background:#f9f7f8;border-radius:13px}
.text-button{border:0;background:transparent;color:var(--rose-dark);font-weight:800;margin-top:16px}

/* CTA and footer */
.final-cta{padding-top:40px}
.final-cta-card{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:48px;border-radius:36px;color:#fff;background: radial-gradient(circle at 90% 20%,rgba(255,255,255,.14),transparent 22%), linear-gradient(135deg,#d85fa0,#9c57f6 60%, #f1c978)}
.final-cta-card .eyebrow{color:#f0d9e1}
.final-cta-card h2{font-size:clamp(2.2rem,3.6vw,3.7rem);margin-bottom:8px}
.final-cta-card p:last-child{margin:0;color:rgba(255,255,255,.75)}
.site-footer{background:#4d2244;color:#f8edf1;padding:68px 0 25px}
.footer-grid{display:grid;grid-template-columns:1.5fr .7fr 1fr;gap:55px}
.footer-logo{width:300px;filter:brightness(0) invert(1);opacity:.94}
.footer-grid p{color:#cbbbc1;max-width:440px}
.footer-grid h3{font-family:Georgia,serif;font-size:1.18rem;margin-bottom:15px}
.footer-grid a,.footer-grid span{display:flex;align-items:center;gap:8px;color:#d9cbd0;margin-bottom:10px;font-size:.89rem}
.footer-grid .ui-icon{width:18px}
.footer-bottom{display:flex;justify-content:space-between;gap:20px;border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding-top:22px;color:#ad9ba2;font-size:.8rem}
.floating-whatsapp{position:fixed;right:20px;bottom:20px;z-index:70;display:flex;align-items:center;gap:9px;background:#25D366;color:#073b1d;padding:13px 17px;border-radius:999px;font-weight:850;box-shadow:0 16px 36px rgba(20,110,55,.25)}
.floating-whatsapp .ui-icon{width:24px;height:24px}

/* reveal */
.reveal-up,.reveal-scale{opacity:1;transform:none}
.js-ready .reveal-up{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease;transition-delay:var(--delay,0ms)}
.js-ready .reveal-scale{opacity:0;transform:scale(.97);transition:opacity .7s ease,transform .7s ease}
.js-ready .reveal-up.is-visible,.js-ready .reveal-scale.is-visible{opacity:1;transform:none}

/* Login */
.admin-login-page{min-height:100vh;background:linear-gradient(135deg,var(--blush-2),var(--cream) 48%,var(--mint));position:relative;overflow-x:hidden}
.login-decoration{position:fixed;border-radius:50%;filter:blur(2px);pointer-events:none}
.login-decoration-one{width:330px;height:330px;left:-140px;top:-120px;background:rgba(238,231,244,.85)}
.login-decoration-two{width:300px;height:300px;right:-120px;bottom:-100px;background:rgba(248,231,236,.85)}
.login-shell{width:min(1080px,calc(100% - 36px));min-height:100vh;margin:auto;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:42px;padding:50px 0;position:relative;z-index:2}
.login-brand-panel{padding:38px}
.login-logo-link img{width:420px;margin-left:-20px}
.login-brand-copy{margin-top:40px}
.login-brand-copy h1{font-size:clamp(3rem,5vw,5rem);margin-bottom:20px}
.login-brand-copy>p:last-child{color:var(--muted);font-size:1.04rem;max-width:540px}
.login-feature-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.login-feature-list span{display:flex;align-items:center;gap:8px;padding:10px 13px;border:1px solid var(--line);background:rgba(255,255,255,.6);border-radius:14px;font-size:.78rem;font-weight:750}
.login-feature-list .ui-icon{width:18px;color:var(--rose-dark)}
.login-card{position:relative;background:#fff;border:1px solid rgba(255,255,255,.9);border-radius:34px;padding:46px;box-shadow:var(--shadow);overflow:hidden}
.login-card::before{content:"";position:absolute;inset:0 0 auto;height:7px;background:linear-gradient(90deg,var(--rose),var(--violet),var(--sage))}
.login-card-mark{width:82px;height:82px;border-radius:24px;overflow:hidden;margin-bottom:22px;box-shadow:var(--shadow-soft)}
.login-card h2{font-size:2.25rem;margin:0 0 5px}
.login-subtitle{color:var(--muted);margin-bottom:25px}
.login-form{margin-top:18px}
.field-with-icon{position:relative}
.field-with-icon>.ui-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--rose-dark);width:18px;z-index:2}
.field-with-icon input{padding-left:42px;padding-right:65px}
.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:0;background:var(--blush);color:var(--rose-dark);font-size:.7rem;font-weight:850;padding:7px 9px;border-radius:9px}
.back-to-site{display:block;text-align:center;color:var(--muted);font-size:.82rem;font-weight:700;margin-top:20px}
.flash-message{padding:13px 15px;border-radius:14px;margin:15px 0;font-size:.84rem}
.flash-success{background:var(--mint);color:#416453}
.flash-error{background:#fff0f2;color:#923e50}

/* Admin layout */
.admin-body{background:#F8F5F6;min-height:100vh}
.admin-layout{display:grid;grid-template-columns:270px minmax(0,1fr);min-height:100vh}
.admin-sidebar{position:sticky;top:0;height:100vh;padding:24px 18px;display:flex;flex-direction:column;background:#fff;border-right:1px solid var(--line);z-index:60}
.admin-logo{display:block;padding:0 8px 16px}
.admin-logo img{width:220px;height:70px;object-fit:contain;object-position:left}
.admin-nav{display:grid;gap:6px;margin-top:10px}
.admin-nav a{display:flex;align-items:center;gap:11px;min-height:48px;padding:10px 13px;border-radius:15px;color:#75666d;font-size:.88rem;font-weight:750;transition:.2s}
.admin-nav a:hover{background:var(--blush-2);color:var(--rose-dark)}
.admin-nav a.is-active{background:linear-gradient(135deg,var(--blush),var(--violet-soft));color:var(--rose-dark)}
.admin-nav a b{margin-left:auto;min-width:22px;height:22px;display:grid;place-items:center;border-radius:99px;background:var(--rose-dark);color:#fff;font-size:.68rem}
.sidebar-status{display:flex;gap:11px;align-items:flex-start;padding:13px;border:1px solid var(--line);border-radius:16px;margin-top:auto;background:#faf8f9}
.sidebar-status strong,.sidebar-status small{display:block}
.sidebar-status strong{font-size:.78rem}
.sidebar-status small{font-size:.68rem;color:var(--muted);line-height:1.35;margin-top:2px}
.view-site-link{display:flex;align-items:center;gap:8px;padding:13px;color:var(--rose-dark);font-size:.78rem;font-weight:800;margin-top:8px}
.view-site-link .ui-icon{width:17px}
.admin-main{min-width:0}
.admin-topbar{height:88px;display:flex;align-items:center;gap:18px;padding:0 32px;background:rgba(248,245,246,.88);backdrop-filter:blur(15px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:45}
.admin-topbar>div:nth-child(2){flex:1}
.admin-topbar p{margin:0;color:var(--muted);font-size:.7rem}
.admin-topbar h1{font-family:Inter,system-ui,sans-serif;font-size:1.25rem;font-weight:850;letter-spacing:-.02em;margin:1px 0 0}
.topbar-actions{display:flex;align-items:center;gap:8px}
.admin-menu-toggle{display:none}
.admin-content{padding:28px 32px 110px;max-width:1450px;margin:auto}
.admin-toast{display:flex;align-items:center;gap:10px;position:fixed;right:24px;top:105px;z-index:100;width:min(390px,calc(100% - 35px));padding:14px 15px;border-radius:16px;box-shadow:var(--shadow);animation:toastIn .28s ease both}
.admin-toast.flash-success{background:#eff8f1;color:#3e684c;border:1px solid rgba(62,104,76,.13)}
.admin-toast.flash-error{background:#fff1f3;color:#923e50;border:1px solid rgba(146,62,80,.13)}
.admin-toast>span{display:grid;place-items:center}
.admin-toast p{margin:0;flex:1;font-size:.84rem;font-weight:750}
.admin-toast button{border:0;background:transparent;color:inherit}
.admin-toast.is-hiding{opacity:0;transform:translateY(-8px);transition:.28s}
@keyframes toastIn{from{opacity:0;transform:translateY(-9px)}to{opacity:1;transform:none}}
.dashboard-welcome{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:27px 29px;border:1px solid var(--line);border-radius:26px;background:linear-gradient(135deg,#fff,var(--blush-2));box-shadow:var(--shadow-soft)}
.dashboard-welcome h2{font-size:2rem;margin:0 0 7px}
.dashboard-welcome>div>p:last-child{margin:0;color:var(--muted);font-size:.88rem}
.today-toggle-card{min-width:290px;display:flex;align-items:center;justify-content:space-between;gap:15px;padding:14px 16px;border:1px solid rgba(102,131,115,.15);background:var(--mint);border-radius:18px}
.today-toggle-card.is-closed{background:#fff0f2;border-color:rgba(135,68,91,.14)}
.today-toggle-card>div{display:grid;grid-template-columns:auto 1fr;column-gap:10px;align-items:center}
.today-toggle-card .status-dot{grid-row:1/3}
.today-toggle-card strong,.today-toggle-card small{display:block}
.today-toggle-card strong{font-size:.8rem}
.today-toggle-card small{font-size:.67rem;color:var(--muted)}
.toggle-switch{width:48px;height:28px;padding:3px;border:0;border-radius:99px;background:var(--sage);transition:.2s}
.toggle-switch span{display:block;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 3px 8px rgba(0,0,0,.15);transition:.2s}
.toggle-switch.is-on{background:var(--rose-dark)}
.toggle-switch.is-on span{transform:translateX(20px)}
.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:18px 0 26px}
.metric-card{display:flex;align-items:center;gap:15px;padding:20px;border-radius:22px;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-soft)}
.metric-card>span{width:50px;height:50px;border-radius:17px;display:grid;place-items:center;flex:none}
.metric-card.rose>span{background:var(--blush);color:var(--rose-dark)}
.metric-card.sage>span{background:var(--mint);color:var(--sage-dark)}
.metric-card.violet>span{background:var(--violet-soft);color:var(--violet)}
.metric-card.gold>span{background:#f8f0dc;color:#9a7531}
.metric-card small,.metric-card strong,.metric-card p{display:block;margin:0}
.metric-card small{color:var(--muted);font-size:.68rem;font-weight:750}
.metric-card strong{font-size:1.75rem;line-height:1.1}
.metric-card p{color:var(--muted);font-size:.67rem}
.admin-section{border:1px solid var(--line);background:#fff;border-radius:25px;padding:23px;margin-bottom:20px;box-shadow:0 8px 30px rgba(85,49,62,.05)}
.admin-section-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:19px}
.admin-section-heading h2{font-family:Inter,system-ui,sans-serif;font-size:1.25rem;font-weight:850;margin:0}
.reservation-list{display:grid;gap:12px}
.reservation-card{position:relative;overflow:hidden;display:grid;grid-template-columns:1fr auto;border:1px solid var(--line);border-radius:20px;background:#fff}
.reservation-card-accent{position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(var(--rose),var(--violet))}
.reservation-main{padding:17px 17px 17px 21px}
.reservation-person{display:flex;align-items:center;gap:11px}
.client-avatar{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,var(--blush),var(--violet-soft));color:var(--rose-dark);display:grid;place-items:center;font-family:Georgia,serif;font-size:1.15rem;font-weight:700;flex:none}
.reservation-person>div:nth-child(2){min-width:0}
.reservation-person h3{font-size:.92rem;margin:0 0 2px}
.reservation-person a{display:flex;align-items:center;gap:5px;color:var(--sage-dark);font-size:.7rem;font-weight:750}
.reservation-person a .ui-icon{width:14px}
.status-badge{display:inline-flex;align-items:center;justify-content:center;width:max-content;padding:5px 9px;border-radius:99px;font-size:.63rem;font-weight:850;margin-left:auto}
.status-pending{background:#fff2d8;color:#8b661e}
.status-approved{background:var(--mint);color:#456b55}
.status-rejected,.status-cancelled{background:#fff0f2;color:#9a4052}
.status-completed{background:var(--violet-soft);color:var(--violet)}
.status-neutral{background:#f0edef;color:#74676d}
.reservation-facts{display:grid;grid-template-columns:1.2fr 1.2fr .8fr .9fr;gap:9px;margin-top:14px}
.reservation-facts>div{display:flex;align-items:center;gap:8px;padding:10px;background:#faf8f9;border-radius:12px;min-width:0}
.reservation-facts .ui-icon{width:16px;color:var(--rose-dark)}
.reservation-facts span:not(.code-dot){min-width:0}
.reservation-facts small,.reservation-facts strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.reservation-facts small{font-size:.58rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.reservation-facts strong{font-size:.7rem}
.code-dot{width:17px;height:17px;border-radius:6px;background:var(--blush);color:var(--rose-dark);display:grid;place-items:center;font-size:.65rem;font-weight:900}
.client-notes{margin-top:11px;padding:11px 13px;border-left:3px solid var(--rose);background:var(--blush-2);border-radius:0 12px 12px 0}
.client-notes strong{font-size:.68rem}
.client-notes p{margin:3px 0 0;color:var(--muted);font-size:.76rem}
.reservation-actions{min-width:145px;padding:14px;border-left:1px solid var(--line);display:flex;flex-direction:column;justify-content:center;gap:7px;background:#fcfafb}
.reservation-actions form{display:block}
.action-button{width:100%;min-height:37px;border:1px solid transparent;border-radius:11px;padding:8px 10px;display:flex;align-items:center;justify-content:center;gap:6px;font-size:.69rem;font-weight:850}
.action-button .ui-icon{width:15px}
.whatsapp-action{background:#e8faee;color:#24733f}
.approve-action{background:var(--mint);color:#456b55}
.reject-action{background:#fff0f2;color:#984155}
.complete-action{background:var(--violet-soft);color:var(--violet)}
.neutral-action{background:#f1eef0;color:#665a60}
.admin-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:35px 20px;border:1px dashed var(--line);border-radius:18px;background:#fcfafb}
.admin-empty>span{width:57px;height:57px;border-radius:18px;background:var(--blush);color:var(--rose-dark);display:grid;place-items:center}
.admin-empty h3{margin:13px 0 4px}
.admin-empty p{margin:0;color:var(--muted);font-size:.82rem}
.filter-card{padding:14px 16px;border:1px solid var(--line);border-radius:20px;background:#fff;margin-bottom:18px}
.filter-row{display:flex;align-items:center;justify-content:space-between;gap:15px}
.filter-chips{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.filter-chips a{padding:8px 11px;border-radius:11px;color:var(--muted);font-size:.7rem;font-weight:800}
.filter-chips a.is-active{background:var(--rose-dark);color:#fff}
.date-filter-form{display:flex;align-items:center;gap:8px}
.date-picker-field{position:relative;display:flex;align-items:center;gap:8px;min-width:190px;min-height:44px;padding:0 10px;border:1px solid var(--line);background:#fff;border-radius:13px;color:var(--rose-dark)}
.date-picker-field.large{min-height:50px}
.date-picker-field input{min-width:0;flex:1;border:0;outline:0;background:transparent;color:var(--ink);font-size:.78rem;cursor:pointer}
.date-picker-field>button{border:0;background:transparent;color:var(--muted);padding:2px}
.date-picker-field .ui-icon{width:17px}
.service-editors{display:grid;gap:11px}
.service-editor-card{border:1px solid var(--line);border-radius:19px;background:#fff;overflow:hidden;margin-bottom:11px}
.service-editor-card.is-inactive{opacity:.78}
.new-service-editor{border-style:dashed;background:var(--blush-2)}
.service-editor-header{width:100%;border:0;background:transparent;display:flex;align-items:center;gap:12px;padding:15px;text-align:left}
.service-admin-icon{width:42px;height:42px;border-radius:13px;background:var(--blush);color:var(--rose-dark);display:grid;place-items:center;flex:none}
.service-editor-header>span:nth-child(2){flex:1}
.service-editor-header strong,.service-editor-header small{display:block}
.service-editor-header strong{font-size:.84rem}
.service-editor-header small{font-size:.68rem;color:var(--muted);margin-top:2px}
.accordion-chevron{width:18px;color:var(--muted);transition:.2s}
.service-editor-card.is-open .accordion-chevron{transform:rotate(180deg)}
.service-editor-content{padding:0 16px 17px;border-top:1px solid var(--line)}
.admin-form{padding-top:16px}
.disabled-field{opacity:.65}
.disabled-field input{background:#f3f0f1}
.custom-toggle-row,.day-toggle{display:flex;align-items:center;gap:11px;margin:7px 0 17px;cursor:pointer}
.custom-toggle-row input,.day-toggle input{position:absolute;opacity:0;pointer-events:none}
.custom-toggle{width:46px;height:27px;padding:3px;border-radius:99px;background:#d8cfd3;flex:none;transition:.2s}
.custom-toggle i{display:block;width:21px;height:21px;border-radius:50%;background:#fff;box-shadow:0 2px 7px rgba(0,0,0,.13);transition:.2s}
.custom-toggle-row input:checked+.custom-toggle,.day-toggle input:checked+.custom-toggle{background:var(--sage)}
.custom-toggle-row input:checked+.custom-toggle i,.day-toggle input:checked+.custom-toggle i{transform:translateX(19px)}
.custom-toggle-row strong,.custom-toggle-row small,.day-toggle strong,.day-toggle small{display:block}
.custom-toggle-row strong,.day-toggle strong{font-size:.76rem}
.custom-toggle-row small,.day-toggle small{font-size:.65rem;color:var(--muted)}
.form-actions{display:flex;gap:10px}
.archive-form{border-top:1px solid var(--line);padding-top:11px}
.danger-text-button{border:0;background:transparent;color:#a64c5e;display:flex;align-items:center;gap:7px;font-size:.7rem;font-weight:800}
.danger-text-button .ui-icon{width:15px}
.today-closure-panel{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:24px;border-radius:24px;margin-bottom:20px;background:linear-gradient(135deg,var(--mint),#f6fbf7);border:1px solid rgba(102,131,115,.12)}
.today-closure-panel.is-closed{background:linear-gradient(135deg,#fff0f2,var(--blush));border-color:rgba(135,68,91,.12)}
.today-closure-copy{display:flex;align-items:center;gap:16px}
.today-closure-icon{width:55px;height:55px;border-radius:18px;background:#fff;color:var(--sage-dark);display:grid;place-items:center;box-shadow:var(--shadow-soft);flex:none}
.today-closure-panel.is-closed .today-closure-icon{color:var(--rose-dark)}
.today-closure-panel h2{font-family:Inter,system-ui,sans-serif;font-size:1.22rem;font-weight:850;margin:0 0 4px}
.today-closure-panel p:last-child{margin:0;color:var(--muted);font-size:.8rem}
.hours-form{display:grid;gap:8px}
.hours-row{display:grid;grid-template-columns:190px 1fr;gap:16px;align-items:center;padding:12px 14px;border:1px solid var(--line);border-radius:17px;background:#fff;transition:.2s}
.hours-row.is-disabled{background:#f7f4f5}
.hours-row.is-disabled .hours-inputs{opacity:.4}
.day-toggle{margin:0}
.hours-inputs{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.hours-inputs label{display:flex;align-items:center;gap:6px;padding:8px 10px;border:1px solid var(--line);border-radius:12px;background:#fff}
.hours-inputs label span{font-size:.6rem;color:var(--muted);text-transform:uppercase;font-weight:750}
.hours-inputs input{width:58px;border:0;outline:0;background:transparent;font-size:.75rem;font-weight:800}
.closure-form{display:grid;grid-template-columns:210px 1fr auto;gap:10px;align-items:end}
.closure-form .field{margin:0}
.closed-dates-list{display:grid;grid-template-columns:repeat(2,1fr);gap:9px;margin-top:18px}
.closed-date-card{display:flex;align-items:center;gap:11px;padding:12px;border:1px solid var(--line);border-radius:16px;background:#fcfafb}
.closed-date-icon{width:39px;height:39px;border-radius:12px;background:var(--violet-soft);color:var(--violet);display:grid;place-items:center}
.closed-date-card>div{flex:1}
.closed-date-card strong,.closed-date-card small{display:block}
.closed-date-card strong{font-size:.75rem}
.closed-date-card small{color:var(--muted);font-size:.65rem}
.settings-grid{display:grid;grid-template-columns:1.4fr .8fr;gap:18px;align-items:start}
.settings-card{border:1px solid var(--line);border-radius:25px;background:#fff;padding:23px;box-shadow:var(--shadow-soft)}
.settings-card:first-child{grid-row:span 2}
.settings-card-heading{display:flex;align-items:center;gap:12px;padding-bottom:17px;border-bottom:1px solid var(--line);margin-bottom:15px}
.settings-card-heading>span{width:45px;height:45px;border-radius:14px;background:var(--blush);color:var(--rose-dark);display:grid;place-items:center}
.settings-card-heading h2{font-family:Inter,system-ui,sans-serif;font-size:1.12rem;font-weight:850;margin:0}
.small-field{max-width:260px}
.password-help{font-size:.7rem;color:var(--muted);margin-top:-4px}
.price-settings-card{background:linear-gradient(145deg,var(--violet-soft),#fff)}
.coming-soon-panel>span{display:inline-block;padding:6px 9px;border-radius:99px;background:var(--violet);color:#fff;font-size:.63rem;font-weight:850}
.coming-soon-panel h3{font-family:Georgia,serif;font-size:1.35rem;margin:13px 0 7px}
.coming-soon-panel p{margin:0;color:var(--muted);font-size:.8rem}
.admin-mobile-nav{display:none}

/* Modals and date picker */
.custom-modal,.date-picker-popover{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:20px}
.custom-modal-backdrop,.date-popover-backdrop{position:absolute;inset:0;background:rgba(45,30,36,.48);backdrop-filter:blur(5px);border:0;width:100%;height:100%}
.custom-modal-card,.date-popover-card{position:relative;z-index:2;width:min(430px,100%);border:1px solid rgba(255,255,255,.65);border-radius:25px;background:#fff;padding:26px;box-shadow:0 30px 80px rgba(42,25,32,.3);animation:modalIn .25s ease both}
.modal-icon{width:58px;height:58px;border-radius:18px;background:var(--blush);color:var(--rose-dark);display:grid;place-items:center;margin-bottom:15px}
.custom-modal-card h2{font-size:1.7rem;margin:0 0 8px}
.custom-modal-card p{color:var(--muted);font-size:.86rem}
.modal-actions{display:flex;justify-content:flex-end;gap:9px;margin-top:22px}
.date-popover-card{width:min(390px,100%)}
@keyframes modalIn{from{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:none}}
.admin-sidebar-backdrop{display:none}

/* responsive */
@media (max-width:1100px){
  .desktop-nav{display:none}
  .mobile-menu-button{display:inline-flex}
  .hero-grid{gap:30px}
  .hero-copy h1{font-size:4.3rem}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .booking-shell{grid-template-columns:1fr}
  .booking-intro{min-height:330px}
  .booking-contact{margin-top:20px}
  .metrics-grid{grid-template-columns:repeat(2,1fr)}
  .reservation-facts{grid-template-columns:repeat(2,1fr)}
  .settings-grid{grid-template-columns:1fr}
  .settings-card:first-child{grid-row:auto}
}
@media (max-width:900px){
  .hero-grid,.experience-grid{grid-template-columns:1fr}
  .hero-copy{order:1}
  .hero-art{max-width:680px;margin:auto}
  .experience-visual{min-height:450px}
  .abstract-nails{height:450px}
  .admin-layout{display:block}
  .admin-sidebar{position:fixed;left:0;top:0;transform:translateX(-105%);transition:.28s;width:280px;box-shadow:var(--shadow);z-index:120}
  .admin-sidebar.is-open{transform:none}
  .admin-sidebar-backdrop{display:block;position:fixed;inset:0;border:0;background:rgba(45,30,36,.35);z-index:110;opacity:0;pointer-events:none;transition:.2s}
  .admin-sidebar-backdrop.is-visible{opacity:1;pointer-events:auto}
  .admin-menu-toggle{display:inline-flex}
  .admin-topbar{padding:0 20px}
  .admin-content{padding:22px 20px 110px}
  .admin-mobile-nav{position:fixed;left:12px;right:12px;bottom:calc(10px + var(--safe-bottom));z-index:90;display:grid;grid-template-columns:repeat(5,1fr);padding:7px;border:1px solid rgba(255,255,255,.8);border-radius:22px;background:rgba(255,255,255,.91);backdrop-filter:blur(17px);box-shadow:0 16px 45px rgba(64,36,47,.18)}
  .admin-mobile-nav a{position:relative;display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 3px;border-radius:15px;color:var(--muted);font-size:.58rem;font-weight:800}
  .admin-mobile-nav a.is-active{background:var(--blush);color:var(--rose-dark)}
  .admin-mobile-nav .ui-icon{width:20px}
  .admin-mobile-nav b{position:absolute;right:12px;top:3px;width:17px;height:17px;border-radius:50%;display:grid;place-items:center;background:var(--rose-dark);color:#fff;font-size:.55rem}
}
@media (max-width:760px){
  .container-shell{width:min(100% - 26px,1180px)}
  .section-space{padding:78px 0}
  .hide-mobile{display:none!important}
  .brand-logo{width:210px;height:66px}
  .header-inner{min-height:72px}
  .hero-section{padding:48px 0 60px}
  .hero-copy h1{font-size:clamp(3.1rem,14vw,4.7rem)}
  .hero-lead{font-size:1rem}
  .hero-art{padding:12px}
  .hero-art-card{border-radius:42px;padding:12px}
  .hero-art-card img{border-radius:32px}
  .floating-card-top{right:0;top:55px}
  .floating-card-bottom{left:0;bottom:42px}
  .services-grid{grid-template-columns:1fr}
  .section-heading{align-items:flex-start;flex-direction:column}
  .service-card p{min-height:0}
  .experience-visual{min-height:390px}
  .abstract-nails{height:390px;border-radius:36px}
  .abstract-hand{transform:scale(.78) rotate(-12deg);transform-origin:left bottom;left:30px;top:130px}
  .abstract-polish{right:28px;bottom:35px;transform:scale(.8) rotate(7deg)}
  .booking-shell{padding:12px;border-radius:28px}
  .booking-intro,.booking-wizard{padding:22px}
  .booking-intro{border-radius:22px}
  .progress-step small{display:none}
  .wizard-progress>i{margin:0 4px}
  .field-grid{grid-template-columns:1fr;gap:0}
  .time-slots{grid-template-columns:repeat(3,1fr)}
  .reservation-summary,.success-details{grid-template-columns:1fr}
  .final-cta-card{align-items:flex-start;flex-direction:column;padding:35px 27px}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .footer-bottom{flex-direction:column}
  .floating-whatsapp span{display:none}
  .floating-whatsapp{width:56px;height:56px;padding:0;justify-content:center;bottom:18px}
  .login-shell{grid-template-columns:1fr;padding:25px 0}
  .login-brand-panel{display:none}
  .login-card{padding:32px 23px;border-radius:27px}
  .dashboard-welcome{align-items:stretch;flex-direction:column}
  .today-toggle-card{min-width:0;width:100%}
  .metrics-grid{grid-template-columns:1fr 1fr}
  .metric-card{padding:15px;align-items:flex-start}
  .metric-card>span{width:41px;height:41px}
  .reservation-card{grid-template-columns:1fr}
  .reservation-actions{min-width:0;border-left:0;border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(2,1fr)}
  .reservation-actions>a{grid-column:1/-1}
  .filter-row{align-items:stretch;flex-direction:column}
  .date-filter-form{width:100%}
  .date-picker-field{flex:1}
  .hours-row{grid-template-columns:1fr}
  .hours-inputs{grid-template-columns:repeat(2,1fr)}
  .closure-form{grid-template-columns:1fr}
  .closed-dates-list{grid-template-columns:1fr}
  .today-closure-panel{align-items:stretch;flex-direction:column}
  .today-closure-panel .button{width:100%}
}
@media (max-width:520px){
  .hero-buttons{display:grid}
  .hero-buttons .button{width:100%}
  .trust-row{display:grid;gap:14px}
  .floating-card{padding:10px 12px}
  .floating-card strong{font-size:.72rem}
  .floating-card small{font-size:.62rem}
  .mini-icon{width:33px;height:33px}
  .experience-visual{min-height:330px}
  .abstract-nails{height:330px}
  .abstract-hand{transform:scale(.64) rotate(-12deg);left:12px;top:110px}
  .abstract-polish{transform:scale(.64) rotate(7deg);right:8px}
  .booking-wizard{padding:18px 13px}
  .booking-intro{padding:25px 20px}
  .wizard-title h3{font-size:1.4rem}
  .time-slots{grid-template-columns:repeat(2,1fr)}
  .metrics-grid{grid-template-columns:1fr}
  .reservation-facts{grid-template-columns:1fr 1fr}
  .reservation-person{align-items:flex-start;flex-wrap:wrap}
  .reservation-person .status-badge{margin-left:53px}
  .admin-content{padding-inline:13px}
  .admin-topbar{padding-inline:13px}
  .admin-topbar h1{font-size:1.02rem}
  .topbar-actions .icon-button:first-child{display:none}
  .admin-section{padding:16px;border-radius:20px}
  .filter-chips{overflow-x:auto;flex-wrap:nowrap;padding-bottom:3px}
  .filter-chips a{white-space:nowrap}
  .date-filter-form{display:grid;grid-template-columns:1fr auto}
  .date-picker-field{grid-column:1/-1}
  .hours-inputs{grid-template-columns:1fr 1fr}
  .hours-inputs label{justify-content:space-between}
  .service-editor-header .status-badge{display:none}
}
@keyframes spin{to{transform:rotate(360deg)}}


.experience-art-card{border-radius:48px;overflow:hidden;background:linear-gradient(145deg,#fff,#f8eeef);box-shadow:var(--shadow);padding:18px;border:1px solid rgba(255,255,255,.85)}
.experience-art-card img{width:100%;display:block;border-radius:34px;background:#fff}
.service-meta-stack{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.service-price{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;background:linear-gradient(135deg,var(--blush),var(--violet-soft));color:var(--rose-dark);font-size:.74rem;font-weight:800;border:1px solid rgba(169,106,123,.12)}
.service-price::before{content:'$';display:none}
.service-card-body{background:linear-gradient(180deg,#fff 0%, #fffafa 100%)}
.service-illustration{height:220px;position:relative;overflow:hidden;background:linear-gradient(145deg,#f7eef1,#eef4ef)}
.service-illustration::before{content:'';position:absolute;inset:20px;border-radius:34px;background:linear-gradient(145deg,rgba(255,255,255,.7),rgba(255,255,255,.22));border:1px solid rgba(255,255,255,.7)}
.service-illustration::after{content:'';position:absolute;width:170px;height:170px;border-radius:50%;background:rgba(255,255,255,.42);right:-55px;top:-45px}
.service-illustration-2{background:linear-gradient(145deg,#f8eef2,#edf4ef)}
.service-illustration-3{background:linear-gradient(145deg,#f7eef1,#f2ebf0)}
.nail-shape{position:absolute;width:86px;height:165px;border-radius:42px 42px 28px 28px;left:50%;top:28px;transform:translateX(-50%) rotate(9deg);background:linear-gradient(180deg,#e6b8c0,#c78596);box-shadow:inset 0 0 0 6px rgba(255,255,255,.5),0 22px 30px rgba(91,51,66,.08);z-index:2}
.polish-shape{position:absolute;width:58px;height:80px;border-radius:16px;right:42px;bottom:22px;background:linear-gradient(180deg,#a96a7b,#8f5e6e);transform:rotate(-8deg);z-index:2}
.polish-shape::before{content:'';position:absolute;left:14px;top:-28px;width:30px;height:32px;border-radius:10px 10px 4px 4px;background:#7c5b69}
.spark-shape{position:absolute;left:46px;top:54px;color:var(--gold);font-size:2.6rem;z-index:2}
.button-primary{background:linear-gradient(135deg,#ec6aa8,#bf4af0);color:white;box-shadow:0 14px 30px rgba(143,94,110,.22)}
.button-violet{background:linear-gradient(135deg,#a85cff,#d858a2);color:#fff;box-shadow:0 14px 30px rgba(129,96,113,.17)}
.button-soft{background:#f6ecf0;color:var(--rose-dark);border-color:rgba(143,94,110,.08)}
.button-light{background:#fff;color:var(--rose-dark);box-shadow:0 14px 36px rgba(65,36,47,.10)}
.status-pill,.floating-card,.booking-note,.benefit-item,.metric-card,.admin-section,.settings-card,.reservation-card,.today-closure-panel,.hours-row,.closed-date-card,.service-editor-card{box-shadow:var(--shadow-soft)}
.mobile-menu-button,.icon-button{border-color:rgba(169,106,123,.12)}
.login-card::before{background:linear-gradient(90deg,#a96a7b,#c9ae74,#bacbbe)}
.metric-card.gold>span{background:#f7f0e0;color:#9f8142}
.price-settings-card{background:linear-gradient(145deg,#fff,#fff0f8)}
.public-price-helper{padding:14px 15px;border-radius:15px;background:#fff7f9;border:1px solid rgba(169,106,123,.1);color:var(--muted);font-size:.8rem;margin:8px 0 18px}
.public-price-toggle-row{margin-top:6px}
.footer-logo{filter:none;opacity:1;background:#fff;padding:8px 12px;border-radius:16px;width:320px}
.floating-whatsapp{background:#25D366;color:#06381c;box-shadow:0 18px 36px rgba(20,110,55,.22)}
@media (max-width:760px){
  .footer-logo{width:240px}
  .experience-art-card{border-radius:34px;padding:12px}
  .experience-art-card img{border-radius:24px}
}


/* ===== Glam refresh v2.2 ===== */
body{background:var(--cream)}
.site-noise{opacity:.22;background-image:url('../img/pattern.svg');background-size:180px 180px}
.brand-logo{width:94px;height:94px;object-fit:contain;display:block;filter:drop-shadow(0 10px 20px rgba(201,75,139,.10))}
.header-inner{padding-top:14px;padding-bottom:14px}
.desktop-nav a:hover,.desktop-nav a:focus{color:var(--rose-dark)}
.icon-button,.mobile-menu-button{background:#fff;border:1px solid rgba(201,75,139,.12);box-shadow:0 12px 26px rgba(201,75,139,.08)}
.hero-section{padding:34px 0 70px;background:
 radial-gradient(circle at 0% 0%, rgba(245,118,189,.18), transparent 25%),
 radial-gradient(circle at 100% 0%, rgba(155,92,246,.13), transparent 24%),
 linear-gradient(180deg,#fffbfd 0%,#fff6fb 62%,#fffbfd 100%)}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(0,.98fr);gap:34px;align-items:center}
.hero-copy{order:1;position:relative;z-index:2}
.hero-art{order:2;position:relative;display:flex;justify-content:center}
.status-pill{margin-bottom:18px;background:#fff;box-shadow:0 18px 38px rgba(201,75,139,.10);border-color:rgba(201,75,139,.10)}
.status-pill strong{color:var(--rose-deep)}
.status-dot{background:linear-gradient(135deg,#d858a2,#9c57f6)}
.eyebrow{letter-spacing:.23em;color:var(--rose-dark)}
.hero-copy h1{font-size:clamp(3.25rem,6vw,5.6rem);line-height:.94;letter-spacing:-.04em;color:var(--ink);margin-bottom:20px}
.hero-copy h1 em{display:block;color:var(--rose-dark);font-style:italic;background:linear-gradient(135deg,#d858a2,#9c57f6);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-lead{font-size:1.1rem;color:var(--muted);max-width:590px}
.hero-buttons{display:flex;gap:14px;flex-wrap:wrap;margin-top:22px}
.button{transition:transform .18s ease, box-shadow .22s ease, border-color .22s ease}
.button:hover{transform:translateY(-2px)}
.button-primary{background:linear-gradient(135deg,#ee73af,#cd4ad9 55%, #9b5cf6);border:none;color:#fff;box-shadow:0 16px 34px rgba(201,75,139,.24)}
.button-soft{background:#fff;border-color:rgba(201,75,139,.12);color:var(--rose-dark)}
.button-violet{background:linear-gradient(135deg,#9b5cf6,#d858a2);border:none;color:#fff}
.button-light{background:#fff;color:var(--rose-deep);border:none}
.trust-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:22px}
.trust-item{background:#fff;border:1px solid rgba(201,75,139,.10);border-radius:24px;padding:16px 18px;box-shadow:0 14px 34px rgba(201,75,139,.08)}
.trust-icon{background:linear-gradient(135deg,#fff0f7,#f2e6ff);color:var(--rose-dark)}
.hero-art-card{width:min(100%,560px);border-radius:44px;padding:14px;background:linear-gradient(145deg,rgba(255,255,255,.96),rgba(255,255,255,.75));border:1px solid rgba(255,255,255,.95);box-shadow:0 34px 70px rgba(201,75,139,.14);transform:none}
.hero-art-card img{display:block;width:100%;border-radius:32px}
.floating-card{background:#fff;box-shadow:0 22px 44px rgba(201,75,139,.14);border:1px solid rgba(201,75,139,.09)}
.floating-card strong{color:var(--ink)}
.mini-icon{background:linear-gradient(135deg,#fff0f7,#f5e7ff);color:var(--rose-dark)}
.mini-icon.mint{background:linear-gradient(135deg,#fff0f7,#f2e6ff);color:var(--violet)}
.floating-card-top{right:-8px;top:26px}
.floating-card-bottom{left:8px;bottom:34px}
.marquee-strip{padding:16px 0}
.section-space{padding:78px 0}
.section-heading h2,.experience-copy h2,.booking-intro h2,.final-cta-card h2{color:var(--ink)}
.section-heading h2 em,.experience-copy h2 em,.booking-intro h2 em{font-style:italic;color:var(--rose-dark)}
.service-card{background:#fff;border:1px solid rgba(201,75,139,.08);box-shadow:0 22px 46px rgba(201,75,139,.08)}
.service-card-body{background:linear-gradient(180deg,#fff 0%, #fff7fb 100%)}
.service-number{background:linear-gradient(135deg,#ffe9f3,#f3e6ff);color:var(--rose-dark)}
.service-illustration{height:210px;background:linear-gradient(145deg,#ffeaf4,#f3e8ff 56%, #fff3da)}
.service-illustration::before{inset:16px;border-radius:28px;background:linear-gradient(145deg,rgba(255,255,255,.75),rgba(255,255,255,.25));border:1px solid rgba(255,255,255,.75)}
.service-illustration::after{display:none}
.nail-shape{background:linear-gradient(180deg,#ffb8d7,#f06bac);box-shadow:inset 0 0 0 6px rgba(255,255,255,.58),0 22px 30px rgba(201,75,139,.12)}
.polish-shape{background:linear-gradient(180deg,#a64fff,#d858a2)}
.polish-shape::before{background:#7d3eda}
.spark-shape{color:#e0b86e}
.round-arrow{background:linear-gradient(135deg,#ee73af,#9b5cf6);color:#fff;border:none;box-shadow:0 12px 24px rgba(201,75,139,.2)}
.service-price{background:linear-gradient(135deg,#fff0f7,#f3e8ff);color:var(--rose-deep);border-color:rgba(201,75,139,.12)}
.experience-section{background:linear-gradient(180deg,#fffafc 0%,#fff4fb 100%)}
.experience-grid{grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);gap:36px;align-items:center}
.experience-art-card{padding:14px;border-radius:36px;background:linear-gradient(145deg,#fff,#fff6fb);border:1px solid rgba(201,75,139,.10);box-shadow:0 26px 56px rgba(201,75,139,.11)}
.experience-art-card img{display:block;width:100%;border-radius:24px}
.benefit-item{background:#fff;border:1px solid rgba(201,75,139,.09)}
.benefit-item span{background:linear-gradient(135deg,#fff0f7,#f4e8ff);color:var(--rose-dark)}
.booking-shell{background:linear-gradient(135deg,#ffffff,#fff8fc);border:1px solid rgba(201,75,139,.10);box-shadow:0 28px 60px rgba(201,75,139,.10)}
.booking-note,.booking-service-option,.field input,.field textarea,.custom-calendar,.wizard-alert,.success-code,.reservation-summary{border-color:rgba(201,75,139,.10)}
.booking-service-option.is-selected,.booking-service-option:hover{border-color:rgba(201,75,139,.35);box-shadow:0 16px 32px rgba(201,75,139,.10)}
.booking-service-icon,.booking-service-check,.progress-step span,.success-icon{background:linear-gradient(135deg,#ffe9f4,#f3e7ff);color:var(--rose-dark)}
.progress-step.is-active span,.progress-step.is-complete span{background:linear-gradient(135deg,#ee73af,#9b5cf6);color:#fff}
.progress-step i,.wizard-progress i{background:rgba(201,75,139,.14)}
.calendar-nav{background:#fff;border-color:rgba(201,75,139,.10)}
.calendar-day.is-selected,.time-slot.is-selected{background:linear-gradient(135deg,#ee73af,#9b5cf6);color:#fff;border-color:transparent}
.final-cta-card{background:linear-gradient(135deg,#ee73af,#cf4ddb 56%,#9b5cf6);box-shadow:0 30px 70px rgba(201,75,139,.18)}
.site-footer{background:linear-gradient(180deg,#592547,#4a1f3c);color:#ffeef7;padding-top:58px}
.footer-grid{gap:28px}
.footer-logo{width:120px;height:120px;object-fit:contain;background:transparent;padding:0;border-radius:0}
.site-footer a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.10)}
.floating-whatsapp{background:#25d366;color:#073921;box-shadow:0 18px 40px rgba(20,110,55,.25)}

/* admin refresh */
.admin-page,.admin-login-page{background:linear-gradient(180deg,#fff9fc 0%,#fff4fb 100%)}
.login-brand-panel,.login-card,.admin-sidebar,.admin-main-card,.metric-card,.reservation-card,.admin-section,.settings-card,.service-editor-card,.today-closure-panel,.hours-row,.closed-date-card,.custom-modal-card,.date-popover-card{border-color:rgba(201,75,139,.10);box-shadow:0 20px 46px rgba(201,75,139,.08)}
.login-brand-panel{background:linear-gradient(135deg,#fff,#fff4fb)}
.login-card{background:#fff}
.admin-sidebar{background:linear-gradient(180deg,#fff,#fff4fb)}
.admin-sidebar .sidebar-nav a.is-active,.admin-mobile-nav a.is-active{background:linear-gradient(135deg,#ffe9f4,#f3e6ff);color:var(--rose-dark)}
.metric-card.primary>span,.service-admin-icon,.today-closure-icon,.settings-card-heading>span{background:linear-gradient(135deg,#ffe9f4,#f2e6ff);color:var(--rose-dark)}
.flash-success{background:#fff0f8;color:#8a2058;border:1px solid rgba(201,75,139,.14)}
.flash-error{background:#fff1f4;color:#a12d5a;border:1px solid rgba(201,75,139,.16)}
.custom-toggle-row .custom-toggle{background:#f2e6ff;border-color:rgba(201,75,139,.16)}
.custom-toggle-row input:checked + .custom-toggle{background:linear-gradient(135deg,#ee73af,#9b5cf6)}
.button-ghost{background:#fff;border-color:rgba(201,75,139,.12);color:var(--rose-dark)}
.password-toggle{color:var(--rose-dark)}

/* mobile tuning */
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr;gap:18px}
  .hero-copy{order:1}
  .hero-art{order:2;margin-top:4px}
  .hero-copy h1{font-size:clamp(2.7rem,14vw,4.2rem)}
  .trust-row{grid-template-columns:1fr}
  .experience-grid{grid-template-columns:1fr}
  .floating-card-top{right:8px;top:14px}
  .floating-card-bottom{left:10px;bottom:18px}
}
@media (max-width: 760px){
  .brand-logo{width:86px;height:86px}
  .hero-section{padding-top:22px}
  .hero-art-card{border-radius:34px;padding:10px}
  .hero-art-card img{border-radius:24px}
  .floating-card{max-width:240px;padding:12px 14px}
  .section-space{padding:62px 0}
  .site-footer{padding-bottom:calc(110px + var(--safe-bottom))}
  .footer-logo{width:104px;height:104px}
}


/* ===== Premium spa polish v2.3 ===== */
.site-noise{display:none!important}
body{background:linear-gradient(180deg,#fff 0%,#fffafc 34%,#fff5f8 68%,#fffafc 100%);}

/* header flotante y moderno tipo Olanaia */
.site-header{position:sticky;top:0;z-index:90;background:transparent;border:0;backdrop-filter:none;padding:16px 0 0}
.header-inner{min-height:88px;border:1px solid rgba(201,75,139,.10);background:rgba(255,255,255,.92);backdrop-filter:blur(22px);border-radius:34px;padding:12px 18px 12px 22px;box-shadow:0 22px 55px rgba(169,72,123,.12)}
.brand-link{display:flex;align-items:center;min-width:0}
.brand-logo{width:88px;height:88px;object-fit:contain}
.desktop-nav{background:rgba(255,246,251,.75);border:1px solid rgba(201,75,139,.08);border-radius:999px;padding:7px 10px;gap:6px}
.desktop-nav a{padding:10px 15px;border-radius:999px;transition:.22s ease}
.desktop-nav a::after{display:none}
.desktop-nav a:hover{background:#fff;color:var(--rose-dark);box-shadow:0 8px 18px rgba(201,75,139,.08)}
.header-actions{gap:8px}
.header-actions .button-primary{box-shadow:0 14px 28px rgba(201,75,139,.20)}
.mobile-menu-button{width:58px;height:58px;border-radius:20px;background:#fff;box-shadow:0 14px 28px rgba(201,75,139,.12)}
.mobile-menu{width:min(1180px,calc(100% - 40px));margin:10px auto 0;border:1px solid rgba(201,75,139,.10);border-radius:24px;background:rgba(255,255,255,.97);box-shadow:0 22px 50px rgba(201,75,139,.12);padding:10px 14px}
.mobile-menu a{border-bottom:1px solid rgba(201,75,139,.07);border-radius:14px;padding:14px 12px}
.mobile-menu a:last-child{border-bottom:0}

/* fondo hero limpio blanco -> rosa champán */
.hero-section{padding:32px 0 76px;background:linear-gradient(180deg,#ffffff 0%,#fffdfd 20%,#fff8fb 68%,#fff2f6 100%)}
.hero-section::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 12% 16%,rgba(255,214,231,.46),transparent 25%),radial-gradient(circle at 88% 12%,rgba(238,221,255,.34),transparent 23%),radial-gradient(circle at 83% 82%,rgba(244,221,185,.18),transparent 26%);pointer-events:none}
.hero-section::after{content:"";position:absolute;left:7%;right:7%;bottom:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,75,139,.14),transparent)}
.hero-grid{position:relative;z-index:1}

/* estado abierto/cerrado animado */
.status-pill{position:relative;overflow:hidden;padding:12px 18px 12px 14px;border-radius:999px;background:rgba(255,255,255,.96);box-shadow:0 18px 38px rgba(201,75,139,.12);border:1px solid rgba(201,75,139,.12);animation:statusFloat 3.8s ease-in-out infinite}
.status-pill::after{content:"";position:absolute;inset:0 auto 0 -55%;width:42%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.75),transparent);transform:skewX(-18deg);animation:statusShine 4.8s ease-in-out infinite}
.status-pill .status-dot{position:relative;background:linear-gradient(135deg,#ff4f9b,#9b5cf6);box-shadow:0 0 0 0 rgba(213,79,147,.38);animation:statusPulse 1.9s ease-out infinite}
.status-pill.is-open .status-dot{background:linear-gradient(135deg,#3ddc97,#58c878)}
.status-pill.is-closed .status-dot{background:linear-gradient(135deg,#ff5a8c,#d64b89)}
.status-pill strong{font-size:.92rem}
.status-pill small{font-size:.76rem}
@keyframes statusPulse{0%{box-shadow:0 0 0 0 rgba(213,79,147,.38)}70%{box-shadow:0 0 0 10px rgba(213,79,147,0)}100%{box-shadow:0 0 0 0 rgba(213,79,147,0)}}
@keyframes statusFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
@keyframes statusShine{0%,68%{left:-55%}88%,100%{left:120%}}

/* tipografía y aire premium */
.hero-copy{padding-top:10px}
.hero-copy h1{max-width:720px;text-shadow:0 6px 24px rgba(102,45,79,.05)}
.hero-lead{line-height:1.85;max-width:610px}
.hero-buttons{margin-top:28px}
.trust-row{margin-top:26px}
.trust-item{border-radius:26px;padding:18px 20px}

/* ilustración principal más discreta, no dominante */
.hero-art-card{background:linear-gradient(145deg,rgba(255,255,255,.92),rgba(255,248,252,.84));box-shadow:0 30px 68px rgba(201,75,139,.12)}
.hero-art-card img{filter:saturate(.92) contrast(.98)}
.floating-card{border-radius:22px}

/* secciones con continuidad de spa */
.marquee-strip{background:linear-gradient(90deg,#c94b8b,#b84ed9 55%,#9b5cf6)}
.section-space{position:relative}
.service-card,.benefit-item,.booking-shell,.settings-card,.admin-section{border-color:rgba(201,75,139,.08)}
.service-card:hover{transform:translateY(-6px);box-shadow:0 28px 60px rgba(201,75,139,.14)}
.experience-section{background:linear-gradient(180deg,#fff7fb 0%,#fff 48%,#fff8fb 100%)}
.booking-section{background:linear-gradient(180deg,#fff 0%,#fff6fa 100%)}
.booking-shell{box-shadow:0 30px 70px rgba(201,75,139,.11)}
.final-cta{background:linear-gradient(180deg,#fff7fb 0%,#fff 100%)}
.final-cta-card{box-shadow:0 30px 72px rgba(201,75,139,.22)}

/* admin unificado */
.admin-body{background:linear-gradient(180deg,#fff9fc 0%,#fff4f9 100%)}
.admin-topbar{background:rgba(255,255,255,.88);backdrop-filter:blur(18px);border-bottom:1px solid rgba(201,75,139,.08)}
.admin-sidebar{background:linear-gradient(180deg,#fff 0%,#fff7fb 100%)}
.admin-logo img{filter:drop-shadow(0 8px 16px rgba(201,75,139,.08))}
.admin-nav a.is-active{background:linear-gradient(135deg,#ffe9f4,#f2e7ff);box-shadow:0 10px 22px rgba(201,75,139,.08)}
.metric-card,.reservation-card,.settings-card,.admin-section{background:rgba(255,255,255,.96)}

@media (max-width:980px){
  .site-header{padding-top:12px}
  .header-inner{width:min(100% - 24px,1180px);border-radius:28px;padding:9px 12px 9px 16px;min-height:78px}
  .brand-logo{width:76px;height:76px}
  .hero-section{padding-top:22px}
  .hero-copy{order:1}
  .hero-art{order:2;margin-top:12px}
}
@media (max-width:760px){
  .site-header{padding-top:10px}
  .header-inner{border-radius:25px}
  .mobile-menu-button{width:54px;height:54px;border-radius:18px}
  .hero-section{padding-bottom:62px}
  .hero-copy h1{line-height:.97}
  .status-pill{margin-bottom:20px}
  .floating-card-top{right:6px;top:12px}
  .floating-card-bottom{left:6px;bottom:16px}
}


/* =========================================================
   PAOLA NAILS PREMIUM SUITE v3.0
   ========================================================= */
:root{
  --spa-pink:#e95da5;
  --spa-fuchsia:#c73d91;
  --spa-violet:#9356e8;
  --spa-champagne:#efd8bd;
  --spa-plum:#4b263f;
  --spa-bg:#fff9fc;
  --spa-glass:rgba(255,255,255,.82);
  --spa-border:rgba(199,61,145,.11);
  --spa-shadow:0 24px 60px rgba(125,45,96,.13);
}

/* public header */
.site-header{top:12px;margin-inline:auto;width:min(1180px,calc(100% - 28px));border-radius:28px;border:1px solid rgba(255,255,255,.92);box-shadow:0 18px 48px rgba(120,51,91,.12);background:rgba(255,255,255,.82);transition:.25s ease;overflow:visible}
.site-header.is-scrolled{top:7px;box-shadow:0 14px 35px rgba(120,51,91,.16);background:rgba(255,255,255,.94)}
.header-inner{min-height:88px;padding-inline:18px}
.site-header .brand-logo{width:92px;height:92px}
.mobile-menu{border-radius:0 0 24px 24px;background:#fff}
.hero-section{padding-top:48px;background:linear-gradient(180deg,#fff 0%,#fff6fb 46%,#fffaf5 100%)}
.status-pill{position:relative;overflow:hidden;isolation:isolate;transition:transform .2s ease,box-shadow .25s ease;box-shadow:0 18px 45px rgba(134,52,104,.12)}
.status-pill::before{content:"";position:absolute;inset:-40% auto -40% -35%;width:28%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.75),transparent);transform:skewX(-18deg);animation:statusShimmer 4.8s ease-in-out infinite;z-index:-1}
.status-pill .status-dot{position:relative;animation:statusPulse 2s ease-in-out infinite}
.status-pill.is-open{border-color:rgba(92,179,128,.2);background:linear-gradient(135deg,#fff,#f3fff7)}
.status-pill.is-open .status-dot{background:#43b978;box-shadow:0 0 0 7px rgba(67,185,120,.12)}
.status-pill.is-closed{border-color:rgba(233,93,165,.18);background:linear-gradient(135deg,#fff,#fff2f8)}
.status-pill.is-closed .status-dot{background:#e95da5;box-shadow:0 0 0 7px rgba(233,93,165,.12)}
@keyframes statusShimmer{0%,65%{left:-35%}100%{left:130%}}
@keyframes statusPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.16)}}
.hero-copy h1{max-width:780px}
.trust-item{backdrop-filter:blur(12px)}
.services-grid{gap:24px}
.service-card{border-radius:30px;overflow:hidden}
.service-card:hover{transform:translateY(-8px) rotate(-.3deg)}
.booking-shell{border-radius:36px}
.final-cta-card{position:relative;overflow:hidden}
.final-cta-card::after{content:"";position:absolute;width:220px;height:220px;border-radius:50%;right:-70px;bottom:-100px;background:rgba(255,255,255,.15)}

/* admin structure */
.admin-body{background:linear-gradient(160deg,#fff9fc 0%,#fff5fb 50%,#fffaf3 100%)}
.admin-layout{grid-template-columns:286px minmax(0,1fr)}
.admin-sidebar{padding:22px 18px;background:linear-gradient(180deg,rgba(255,255,255,.97),rgba(255,247,252,.96));border-right:1px solid var(--spa-border);box-shadow:18px 0 50px rgba(125,45,96,.05)}
.admin-logo img{width:104px;height:104px;margin:auto;object-position:center}
.admin-nav{gap:7px}
.admin-nav a{position:relative;min-height:52px;border-radius:17px;padding:11px 14px;transition:.2s ease}
.admin-nav a .ui-icon{width:21px;height:21px}
.admin-nav a.is-active{background:linear-gradient(135deg,#ffe7f3,#f1e5ff);color:var(--spa-fuchsia);box-shadow:0 12px 24px rgba(199,61,145,.1)}
.admin-nav a.is-active::before{content:"";position:absolute;left:-6px;width:4px;height:24px;border-radius:999px;background:linear-gradient(#e95da5,#9356e8)}
.sidebar-status{border-radius:20px;background:linear-gradient(135deg,#fff,#fff5fa)}
.view-site-link{border-radius:16px;background:#fff5fa;margin-top:10px}
.admin-main{background:transparent}
.admin-topbar{height:94px;padding:0 34px;background:rgba(255,249,252,.86);border-bottom:1px solid var(--spa-border);backdrop-filter:blur(18px)}
.admin-topbar h1{font-size:1.34rem;color:var(--spa-plum)}
.admin-content{padding:30px 34px 125px}

/* premium dashboard */
.premium-dashboard-hero{position:relative;overflow:hidden;display:grid;grid-template-columns:minmax(0,1.25fr) minmax(330px,.75fr);gap:24px;align-items:stretch;padding:32px;background:linear-gradient(135deg,#fff 0%,#fff1f8 55%,#f7edff 100%);border:1px solid rgba(199,61,145,.1);border-radius:34px;box-shadow:var(--spa-shadow)}
.premium-dashboard-hero::before{content:"";position:absolute;right:-80px;top:-100px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(147,86,232,.18),transparent 66%)}
.premium-dashboard-hero::after{content:"";position:absolute;left:42%;bottom:-120px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(239,216,189,.28),transparent 68%)}
.dashboard-hero-copy,.dashboard-status-stack{position:relative;z-index:2}
.dashboard-kicker{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#fff;color:var(--spa-fuchsia);font-size:.72rem;font-weight:850;box-shadow:0 10px 22px rgba(199,61,145,.09);margin-bottom:16px}
.dashboard-kicker .ui-icon{width:16px}
.premium-dashboard-hero h2{font-size:clamp(2.1rem,3.4vw,3.5rem);max-width:720px;margin-bottom:12px;color:var(--spa-plum)}
.dashboard-hero-copy>p:last-of-type{color:var(--muted);max-width:690px}
.dashboard-quick-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:23px}
.quick-action{display:flex;align-items:center;gap:11px;padding:13px;border-radius:18px;background:rgba(255,255,255,.82);border:1px solid rgba(199,61,145,.09);box-shadow:0 12px 28px rgba(125,45,96,.07);transition:.2s}
.quick-action:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(125,45,96,.11)}
.quick-action>span{width:38px;height:38px;border-radius:13px;display:grid;place-items:center;background:linear-gradient(135deg,#ffe6f2,#efe2ff);color:var(--spa-fuchsia);flex:none}
.quick-action.primary>span{background:linear-gradient(135deg,#e95da5,#9356e8);color:#fff}
.quick-action strong,.quick-action small{display:block}
.quick-action strong{font-size:.75rem;color:var(--spa-plum)}
.quick-action small{font-size:.62rem;color:var(--muted)}
.dashboard-status-stack{display:grid;gap:12px;align-content:center}
.live-business-card{display:flex;align-items:center;gap:16px;padding:20px;border-radius:25px;background:rgba(255,255,255,.88);border:1px solid rgba(199,61,145,.1);box-shadow:0 18px 38px rgba(125,45,96,.1)}
.live-status-orbit{width:60px;height:60px;border-radius:50%;display:grid;place-items:center;background:rgba(233,93,165,.08);flex:none;position:relative}
.live-status-orbit::before,.live-status-orbit::after{content:"";position:absolute;border-radius:50%;border:1px solid currentColor;opacity:.22;animation:orbitPulse 2.4s ease-out infinite}
.live-status-orbit::before{inset:7px}.live-status-orbit::after{inset:0;animation-delay:.6s}
.live-status-orbit span{width:18px;height:18px;border-radius:50%;background:#e95da5;box-shadow:0 0 0 7px rgba(233,93,165,.12)}
.live-business-card.is-open{color:#3b9d68}
.live-business-card.is-open .live-status-orbit{background:rgba(67,185,120,.08)}
.live-business-card.is-open .live-status-orbit span{background:#43b978;box-shadow:0 0 0 7px rgba(67,185,120,.12)}
.live-business-card small,.live-business-card strong,.live-business-card p{display:block;margin:0}
.live-business-card small{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.live-business-card strong{font-size:1.15rem;color:var(--spa-plum)}
.live-business-card p{font-size:.73rem;color:var(--muted);margin-top:3px}
@keyframes orbitPulse{0%{transform:scale(.75);opacity:.32}100%{transform:scale(1.18);opacity:0}}
.premium-metrics{gap:16px}
.premium-metrics .metric-card{position:relative;overflow:hidden;border-radius:24px;padding:22px;background:rgba(255,255,255,.9);border:1px solid rgba(199,61,145,.09);box-shadow:0 16px 36px rgba(125,45,96,.07);transition:.2s}
.premium-metrics .metric-card:hover{transform:translateY(-4px)}
.premium-metrics .metric-card::after{content:"";position:absolute;width:80px;height:80px;border-radius:50%;right:-26px;bottom:-32px;background:currentColor;opacity:.045}
.premium-metrics .metric-card strong{font-size:2rem;color:var(--spa-plum)}
.admin-section{border-radius:28px;border-color:rgba(199,61,145,.09);box-shadow:0 16px 38px rgba(125,45,96,.06)}
.reservation-card{border-radius:22px;transition:.2s ease}
.reservation-card:hover{transform:translateY(-2px);box-shadow:0 16px 35px rgba(125,45,96,.09)}
.reservation-card-accent{width:5px;background:linear-gradient(#e95da5,#9356e8)}
.filter-card{position:sticky;top:108px;z-index:30;backdrop-filter:blur(16px);background:rgba(255,255,255,.88);border-color:rgba(199,61,145,.1);box-shadow:0 14px 30px rgba(125,45,96,.06)}
.filter-chips a.is-active{background:linear-gradient(135deg,#e95da5,#9356e8);box-shadow:0 10px 22px rgba(199,61,145,.2)}
.service-editor-card{border-radius:22px}
.service-admin-icon{background:linear-gradient(135deg,#ffe6f2,#efe2ff)}
.hours-row,.closed-date-card,.settings-card{border-radius:22px}

/* Approval modal */
.approval-success-modal{display:grid}
.approval-success-modal.is-closing{opacity:0;transition:.24s}
.approval-modal-card{text-align:center;max-width:510px;padding:34px;border-radius:32px;background:linear-gradient(180deg,#fff,#fff7fb)}
.approval-icon{margin:0 auto 12px;width:72px;height:72px;border-radius:24px;background:linear-gradient(135deg,#e95da5,#9356e8);color:#fff;box-shadow:0 18px 36px rgba(199,61,145,.22)}
.approval-modal-card h2{font-size:2rem}
.approval-celebration{height:0;position:relative;pointer-events:none}
.approval-celebration span{position:absolute;color:#e0b86e;font-size:1.2rem;animation:celebrate 1.8s ease-in-out infinite}
.approval-celebration span:nth-child(1){left:12%;top:16px}.approval-celebration span:nth-child(2){right:15%;top:40px;animation-delay:.4s}.approval-celebration span:nth-child(3){right:5%;top:-8px;animation-delay:.8s}
@keyframes celebrate{0%,100%{transform:translateY(0) rotate(0);opacity:.55}50%{transform:translateY(-10px) rotate(18deg);opacity:1}}
.approval-summary{display:grid;grid-template-columns:1.2fr 1fr .7fr;gap:8px;margin:20px 0}
.approval-summary div{padding:12px;border-radius:16px;background:#fff;border:1px solid rgba(199,61,145,.09)}
.approval-summary small,.approval-summary strong{display:block}
.approval-summary small{font-size:.63rem;text-transform:uppercase;color:var(--muted)}
.approval-summary strong{font-size:.78rem;color:var(--spa-plum)}

/* Bottom nav */
.admin-mobile-nav{background:rgba(255,255,255,.92);border:1px solid rgba(255,255,255,.96);box-shadow:0 18px 52px rgba(85,30,67,.22);padding:7px;border-radius:27px;backdrop-filter:blur(20px)}
.admin-mobile-nav a{min-height:60px;border-radius:20px;gap:4px;transition:.18s ease;color:#8d7182}
.admin-mobile-nav .mobile-nav-icon{width:31px;height:31px;border-radius:12px;display:grid;place-items:center;transition:.18s ease}
.admin-mobile-nav a.is-active{background:linear-gradient(135deg,#ffe5f2,#efe3ff);color:var(--spa-fuchsia)}
.admin-mobile-nav a.is-active .mobile-nav-icon{background:linear-gradient(135deg,#e95da5,#9356e8);color:#fff;box-shadow:0 10px 20px rgba(199,61,145,.22);transform:translateY(-4px)}
.admin-mobile-nav a.is-pressed{transform:scale(.94)}
.admin-mobile-nav b{background:linear-gradient(135deg,#e95da5,#9356e8)}

/* submit feedback */
button.is-submitting{position:relative;color:transparent!important;pointer-events:none}
button.is-submitting::after{content:"";position:absolute;width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.45);border-top-color:#fff;animation:spin .7s linear infinite}
.button-ghost.is-submitting::after{border-color:rgba(199,61,145,.2);border-top-color:var(--spa-fuchsia)}

@media (max-width:1100px){
  .premium-dashboard-hero{grid-template-columns:1fr}
  .dashboard-status-stack{grid-template-columns:1fr 1fr}
}
@media (max-width:900px){
  .admin-content{padding:22px 20px 125px}
  .admin-topbar{height:82px;padding:0 18px}
  .premium-dashboard-hero{padding:24px;border-radius:28px}
  .dashboard-quick-actions{grid-template-columns:repeat(3,1fr)}
  .filter-card{top:94px}
}
@media (max-width:680px){
  .premium-dashboard-hero{padding:22px 18px}
  .premium-dashboard-hero h2{font-size:2.25rem}
  .dashboard-quick-actions{grid-template-columns:1fr}
  .quick-action{min-height:64px}
  .dashboard-status-stack{grid-template-columns:1fr}
  .premium-metrics{grid-template-columns:1fr 1fr}
  .approval-summary{grid-template-columns:1fr}
  .stacked-mobile{display:grid;grid-template-columns:1fr}
  .stacked-mobile .button{width:100%}
  .filter-card{position:static}
}
@media (max-width:480px){
  .premium-metrics{grid-template-columns:1fr}
  .admin-content{padding-inline:12px}
  .admin-mobile-nav{left:8px;right:8px;bottom:calc(8px + var(--safe-bottom))}
  .admin-mobile-nav a{font-size:.56rem}
  .approval-modal-card{padding:28px 20px}
}
@media (prefers-reduced-motion:reduce){
  .status-pill::before,.status-pill .status-dot,.live-status-orbit::before,.live-status-orbit::after,.approval-celebration span{animation:none!important}
}


/* ===== Premium Suite v3.1: responsive nav, alerts, images and Nunito ===== */
html,body,button,input,textarea,select{font-family:"Nunito",ui-rounded,"SF Pro Rounded","Segoe UI",system-ui,sans-serif}
h1,h2,h3,.hero-copy h1,.section-heading h2,.experience-copy h2,.booking-intro h2,.final-cta-card h2,.dashboard-hero-copy h2{font-family:"Nunito",ui-rounded,"SF Pro Rounded","Segoe UI",system-ui,sans-serif;font-weight:900;letter-spacing:-.035em}
.hero-copy h1 em,.section-heading h2 em,.experience-copy h2 em,.booking-intro h2 em{font-family:"Nunito",ui-rounded,sans-serif;font-weight:900}

/* bottom navigation completely attached to phone edges */
@media (max-width:900px){
  .admin-mobile-nav{left:0!important;right:0!important;bottom:0!important;width:100%!important;margin:0!important;border-radius:26px 26px 0 0!important;padding:10px 8px calc(10px + env(safe-area-inset-bottom,0px))!important;border-left:0!important;border-right:0!important;border-bottom:0!important;box-shadow:0 -16px 45px rgba(83,34,67,.16)!important}
  .admin-content{padding-bottom:calc(118px + env(safe-area-inset-bottom,0px))!important}
  .admin-mobile-nav a{min-height:66px;border-radius:18px!important}
  .admin-mobile-nav a.is-active{background:linear-gradient(145deg,#ffe7f4,#efe4ff)!important;box-shadow:inset 0 0 0 1px rgba(201,75,139,.08)}
  .admin-mobile-nav .ui-icon{width:25px!important;height:25px!important}
}

/* alert center */
.system-alerts{margin:18px 0 24px;padding:22px;border-radius:28px;background:#fff;border:1px solid rgba(201,75,139,.09);box-shadow:0 20px 50px rgba(201,75,139,.08)}
.system-alerts-heading{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:15px}
.system-alerts-heading>div{display:flex;align-items:center;gap:12px}
.system-alerts-heading>div>span{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#e75aa3,#9b5cf6)}
.system-alerts-heading h2{margin:0;font-size:1.18rem}.system-alerts-heading .eyebrow{margin:0 0 2px}.system-alerts-heading>small{padding:7px 11px;border-radius:999px;background:#fff1f8;color:#b73d7b;font-weight:900;font-size:.72rem}
.system-alerts-list{display:grid;gap:10px}
.system-alert{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:13px;padding:15px;border-radius:19px;border:1px solid transparent;transition:.2s ease}
.system-alert:hover{transform:translateY(-2px)}
.system-alert-icon{width:45px;height:45px;border-radius:15px;display:grid;place-items:center}.system-alert-icon .ui-icon{width:21px;height:21px}
.system-alert strong{display:block;font-size:.86rem;color:var(--ink)}.system-alert p{margin:2px 0 0;color:var(--muted);font-size:.73rem;line-height:1.4}.system-alert-arrow{color:currentColor;opacity:.65}.system-alert-arrow .ui-icon{width:18px}
.alert-high{background:#fff0f4;border-color:#ffd3df;color:#d4436d}.alert-high .system-alert-icon{background:#ffdce6;color:#d4436d}
.alert-medium{background:#fff7e8;border-color:#ffe4ad;color:#bd7d19}.alert-medium .system-alert-icon{background:#ffebc2;color:#b87510}
.alert-info{background:#f2efff;border-color:#dfd5ff;color:#7b55c7}.alert-info .system-alert-icon{background:#e7dfff;color:#7850c7}
.alert-success{background:#edfbf4;border-color:#cceede;color:#378564}.alert-success .system-alert-icon{background:#d8f4e5;color:#378564}

/* service image admin */
.service-image-manager{display:grid;grid-template-columns:150px 1fr;gap:14px;align-items:stretch;margin:8px 0 16px}
.service-image-preview{height:135px;border-radius:20px;overflow:hidden;background:linear-gradient(145deg,#fff0f8,#f1e8ff);border:1px dashed rgba(201,75,139,.22);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;color:var(--rose-dark);font-size:.72rem;font-weight:800}
.service-image-preview img{width:100%;height:100%;object-fit:cover;display:block}
.service-image-preview .ui-icon{width:28px;height:28px}
.service-image-upload{position:relative;display:flex;align-items:center;gap:13px;min-height:100px;padding:17px;border-radius:20px;background:#fff8fc;border:1px solid rgba(201,75,139,.11);cursor:pointer;transition:.2s}
.service-image-upload:hover{border-color:rgba(201,75,139,.32);transform:translateY(-1px)}
.service-image-upload>.ui-icon{width:27px;height:27px;color:var(--rose-dark);flex:none}.service-image-upload strong,.service-image-upload small{display:block}.service-image-upload strong{font-size:.82rem}.service-image-upload small{font-size:.68rem;color:var(--muted);margin-top:3px}.service-image-upload input{position:absolute;inset:0;opacity:0;cursor:pointer}
.service-image-controls{display:grid;gap:9px}.remove-image-check{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:13px;background:#fff0f3;color:#a73b5c;font-size:.72rem;font-weight:800;cursor:pointer}.remove-image-check input{accent-color:#d84e89}
.delete-action{background:#ffe8ee!important;color:#b52d57!important}

/* uploaded service photos on public site */
.service-illustration.has-service-photo{padding:0;background:#fff!important}
.service-illustration.has-service-photo::before,.service-illustration.has-service-photo::after{display:none!important}
.service-illustration.has-service-photo img{width:100%;height:100%;display:block;object-fit:cover;object-position:center;transition:transform .5s ease}
.service-card:hover .service-illustration.has-service-photo img{transform:scale(1.045)}

@media(max-width:620px){
 .system-alerts{padding:17px;border-radius:23px}.system-alerts-heading{align-items:flex-start}.system-alert{padding:13px;grid-template-columns:auto 1fr}.system-alert-arrow{display:none}
 .service-image-manager{grid-template-columns:1fr}.service-image-preview{height:190px}.service-image-upload{min-height:84px}
}


/* ===== Suite v3.2: voz de Paola, footer champagne y visuales limpios ===== */
.floating-card{animation:spaFloat 4.8s ease-in-out infinite}.floating-card-bottom{animation-delay:-2.1s}@keyframes spaFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.site-footer{background:linear-gradient(180deg,#fff9fc 0%,#fff1f7 100%)!important;color:var(--ink)!important;padding:36px 0 26px!important;border-top:1px solid rgba(201,75,139,.10)}
.footer-premium-card{background:rgba(255,255,255,.88);border:1px solid rgba(201,75,139,.10);border-radius:34px;padding:28px;box-shadow:0 24px 64px rgba(201,75,139,.10);backdrop-filter:blur(18px)}
.footer-brand-block{display:grid;grid-template-columns:112px 1fr;gap:22px;align-items:center}.footer-logo{width:112px!important;height:112px!important;object-fit:contain!important;background:transparent!important;padding:0!important;filter:none!important}.footer-brand-block h2{font-family:Nunito,system-ui,sans-serif;font-size:clamp(1.6rem,3vw,2.45rem);line-height:1.08;margin:0 0 8px;color:var(--ink);font-weight:900;letter-spacing:-.035em}.footer-brand-block p:last-child{margin:0;color:var(--muted);max-width:680px}
.footer-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:24px 0}.footer-action{display:flex!important;align-items:center!important;gap:13px!important;padding:15px 17px!important;margin:0!important;border-radius:20px;background:#fff;color:var(--ink)!important;border:1px solid rgba(201,75,139,.10);box-shadow:0 12px 30px rgba(201,75,139,.07);transition:.2s ease}.footer-action:hover{transform:translateY(-2px);box-shadow:0 18px 36px rgba(201,75,139,.12)}.footer-action .ui-icon{width:26px!important;height:26px!important;color:var(--rose-dark)}.footer-action small,.footer-action strong{display:block}.footer-action small{font-size:.68rem;color:var(--muted);font-weight:700}.footer-action strong{font-size:.94rem;color:var(--ink)}.footer-action.whatsapp{background:linear-gradient(135deg,#effdf4,#fff)}.footer-action.instagram{background:linear-gradient(135deg,#fff0f8,#f4ecff)}
.footer-links{display:flex;flex-wrap:wrap;align-items:center;gap:10px 22px;padding:18px 0;border-top:1px solid rgba(201,75,139,.09);border-bottom:1px solid rgba(201,75,139,.09)}.footer-links a,.footer-links span{display:inline-flex!important;margin:0!important;color:var(--muted)!important;font-size:.82rem;font-weight:800}.footer-links a:hover{color:var(--rose-dark)!important}.footer-bottom{margin-top:0!important;padding-top:17px!important;border-top:0!important;color:var(--muted)!important}.footer-bottom a{color:var(--muted)!important}
.admin-mobile-nav .mobile-nav-icon{overflow:hidden}.admin-mobile-nav .mobile-nav-icon svg{display:block!important;width:25px!important;height:25px!important;flex:none}.admin-mobile-nav a[href*="tab=servicios"] .mobile-nav-icon{background:transparent}.admin-mobile-nav a[href*="tab=servicios"].is-active .mobile-nav-icon{background:linear-gradient(135deg,#e95da5,#9356e8)}.approval-modal-card h2{font-family:Nunito,system-ui,sans-serif;font-weight:900;letter-spacing:-.025em}
@media(max-width:760px){.footer-premium-card{padding:22px 18px;border-radius:28px}.footer-brand-block{grid-template-columns:80px 1fr;gap:14px}.footer-logo{width:80px!important;height:80px!important}.footer-actions{grid-template-columns:1fr}.footer-links{gap:13px 18px}.site-footer{padding-bottom:calc(110px + var(--safe-bottom))!important}}


/* FINAL POLISH v3.3 */
body{font-family:"Nunito",ui-rounded,"Avenir Next",system-ui,-apple-system,sans-serif;background:linear-gradient(180deg,#fffafd 0%,#fff5fa 50%,#fffafc 100%)}
h1,h2,h3{letter-spacing:-.035em}.site-header{margin:14px 18px 0;border-radius:34px;border:1px solid rgba(201,75,139,.10);box-shadow:0 22px 60px rgba(201,75,139,.12);overflow:hidden}.header-inner{padding-inline:22px}.hero-section{padding-top:42px}.hero-art-card,.experience-art-card{overflow:hidden}.hero-art-card img,.experience-art-card img{display:block;width:100%;height:auto}.floating-card{display:none!important}
.site-footer{background:transparent!important;color:var(--ink)!important;padding:28px 0 calc(34px + var(--safe-bottom))!important;border:0!important}.footer-premium-card{display:grid!important;grid-template-columns:1.35fr .65fr!important;gap:26px!important;padding:30px!important;border-radius:36px!important;background:linear-gradient(135deg,#fff 0%,#fff0f7 58%,#f4eaff 100%)!important;border:1px solid rgba(201,75,139,.12)!important;box-shadow:0 26px 70px rgba(201,75,139,.12)!important}.footer-brand-block{display:grid!important;grid-template-columns:100px 1fr!important;align-items:center!important;gap:20px!important}.footer-brand-block h2{font-size:clamp(1.8rem,3vw,2.7rem)!important;margin:0 0 8px!important}.footer-brand-block p{color:var(--muted)!important;margin:0!important}.footer-actions{display:grid!important;gap:12px!important}.footer-action{display:flex!important;align-items:center!important;gap:12px!important;padding:14px 16px!important;border-radius:20px!important;background:#fff!important;border:1px solid rgba(201,75,139,.10)!important;color:var(--ink)!important;box-shadow:0 12px 28px rgba(201,75,139,.08)!important}.footer-action .ui-icon{width:24px!important;height:24px!important;color:var(--rose-dark)!important}.footer-action span{display:block!important;margin:0!important}.footer-action small,.footer-action strong{display:block!important}.footer-action small{color:var(--muted)!important;font-size:.72rem!important}.footer-links{grid-column:1/-1!important;display:flex!important;align-items:center!important;gap:10px 22px!important;flex-wrap:wrap!important;padding-top:18px!important;border-top:1px solid rgba(201,75,139,.10)!important}.footer-links a,.footer-links span{margin:0!important;color:var(--muted)!important;font-weight:800!important}.footer-bottom{grid-column:1/-1!important;display:flex!important;justify-content:space-between!important;color:var(--muted)!important;margin:0!important;padding-top:14px!important;border-top:1px solid rgba(201,75,139,.08)!important}
.admin-mobile-nav{left:0!important;right:0!important;bottom:0!important;border-radius:28px 28px 0 0!important;padding:9px 10px calc(9px + var(--safe-bottom))!important;border-left:0!important;border-right:0!important;border-bottom:0!important;background:rgba(255,255,255,.96)!important;box-shadow:0 -14px 38px rgba(89,35,70,.14)!important}.admin-mobile-nav a{border-radius:20px!important}.admin-mobile-nav a.is-active{background:linear-gradient(135deg,#ffe9f5,#efe5ff)!important;box-shadow:inset 0 0 0 1px rgba(201,75,139,.08)!important}.mobile-nav-icon img{display:none!important}
.quick-action-button{border:0;text-align:left;width:100%;font:inherit;cursor:pointer}.admin-booking-card{width:min(760px,calc(100vw - 24px));max-height:min(880px,92vh);overflow:auto;padding:28px;border-radius:32px}.modal-close-round{position:absolute;right:18px;top:18px;width:42px;height:42px;border:0;border-radius:15px;background:#fff0f7;color:var(--rose-dark);display:grid;place-items:center}.booking-modal-heading{display:flex;gap:15px;align-items:flex-start;padding-right:46px;margin-bottom:20px}.booking-modal-heading h2{font-size:2rem;margin:0 0 3px}.booking-modal-heading p:last-child{color:var(--muted);margin:0}.booking-modal-icon{width:54px;height:54px;border-radius:18px;background:linear-gradient(135deg,#ffe6f3,#eee2ff);color:var(--rose-dark);display:grid;place-items:center;flex:none}.booking-form-section{padding:18px;border-radius:24px;background:#fff9fc;border:1px solid rgba(201,75,139,.09);margin-bottom:14px}.booking-form-label{display:flex;align-items:center;gap:9px;margin-bottom:13px}.booking-form-label>span{width:28px;height:28px;border-radius:10px;background:linear-gradient(135deg,#ee73af,#9b5cf6);color:#fff;display:grid;place-items:center;font-weight:900;font-size:.74rem}.booking-two-columns{display:grid;grid-template-columns:.8fr 1.2fr;gap:16px}.admin-service-picker{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.admin-service-choice{display:flex;align-items:center;gap:10px;text-align:left;padding:12px;border:1px solid rgba(201,75,139,.10);border-radius:18px;background:#fff;color:var(--ink)}.admin-service-choice>span{width:39px;height:39px;border-radius:13px;background:#fff0f7;color:var(--rose-dark);display:grid;place-items:center}.admin-service-choice div{flex:1}.admin-service-choice strong,.admin-service-choice small{display:block}.admin-service-choice small{color:var(--muted);font-size:.72rem}.admin-service-choice i{width:25px;height:25px;border-radius:50%;background:#f2edf0;color:transparent;display:grid;place-items:center}.admin-service-choice.is-selected{border-color:#d858a2;background:linear-gradient(135deg,#fff4fa,#f8f0ff);box-shadow:0 10px 22px rgba(201,75,139,.10)}.admin-service-choice.is-selected i{background:linear-gradient(135deg,#ee73af,#9b5cf6);color:#fff}.admin-time-picker{display:flex;gap:8px;flex-wrap:wrap;min-height:52px;align-items:center}.admin-time-picker>p{color:var(--muted);font-size:.82rem;margin:0}.admin-time-choice{border:1px solid rgba(201,75,139,.10);background:#fff;border-radius:13px;padding:9px 12px;color:var(--ink);font-weight:800}.admin-time-choice.is-selected{background:linear-gradient(135deg,#ee73af,#9b5cf6);color:#fff;border-color:transparent}.admin-slot-loader{display:flex;gap:5px}.admin-slot-loader i{width:8px;height:8px;border-radius:50%;background:#d858a2;animation:pulseDot .8s infinite alternate}.admin-slot-loader i:nth-child(2){animation-delay:.15s}.admin-slot-loader i:nth-child(3){animation-delay:.3s}.manual-booking-summary{display:flex;align-items:center;gap:10px;padding:14px 16px;border-radius:18px;background:linear-gradient(135deg,#fff0f7,#f3e9ff);color:var(--rose-deep);margin-bottom:15px}.manual-booking-summary p{margin:0}.manual-booking-summary>span{font-size:1.2rem}.admin-content{padding-bottom:calc(118px + var(--safe-bottom))}
@media(max-width:760px){.site-header{margin:12px 12px 0;border-radius:30px}.footer-premium-card{grid-template-columns:1fr!important;padding:22px 18px!important;border-radius:30px!important}.footer-brand-block{grid-template-columns:78px 1fr!important}.footer-actions{grid-template-columns:1fr 1fr!important}.footer-links{display:grid!important;grid-template-columns:1fr 1fr!important}.footer-bottom{flex-direction:column!important;gap:8px!important}.booking-two-columns,.admin-service-picker{grid-template-columns:1fr}.admin-booking-card{padding:22px 16px 18px;border-radius:28px}.booking-modal-heading h2{font-size:1.65rem}.admin-service-choice{padding:11px}.dashboard-quick-actions{grid-template-columns:1fr!important}.admin-section-heading{align-items:flex-start;flex-wrap:wrap}.admin-section-heading .button{width:100%}}
