@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Playfair+Display:wght@600;700;800;900&display=swap');
:root{
  --primary:#c9952e;
  --secondary:#111111;
  --accent:#d4a853;
  --surface:#171717;
  --surface-2:#1f1f1f;
  --bg:#070707;
  --bg-soft:#111111;
  --text:#f5f5f5;
  --muted:#b0b4bd;
  --button:#c9952e;
  --button-text:#111111;
  --radius:20px;
  --shadow:0 18px 50px rgba(0,0,0,.18);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;background:#f3f5f9;color:#0f172a}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
.container{width:min(1200px,calc(100% - 32px));margin-inline:auto}
.hidden{display:none!important}
.section-kicker{font-size:.85rem;text-transform:uppercase;letter-spacing:.35em;color:var(--primary);font-weight:700}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(2.3rem,4vw,4rem);line-height:1.04;font-weight:800;letter-spacing:-.03em}
.section-subtitle{color:#64748b;font-size:1.05rem;line-height:1.7;max-width:60ch}
.page-title{font-size:2.6rem;font-weight:900;letter-spacing:-.04em;color:#0f2347;margin:0}
.card{background:#fff;border:1px solid #e5e7eb;border-radius:24px;box-shadow:0 16px 40px rgba(15,23,42,.05)}
.card-dark{background:linear-gradient(180deg,var(--surface) 0%, #121212 100%);color:var(--text);border:1px solid rgba(255,255,255,.06);border-radius:28px;box-shadow:0 18px 60px rgba(0,0,0,.28)}
.panel{background:#fff;border:1px solid #e7ebf3;border-radius:26px;box-shadow:0 12px 30px rgba(15,23,42,.05)}
.btn-primary,.btn-secondary,.btn-ghost,.btn-danger,.btn-success{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;border:none;border-radius:16px;padding:.95rem 1.15rem;font-weight:800;transition:.22s;cursor:pointer;text-decoration:none}
.btn-primary{background:var(--button);color:var(--button-text)}
.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.03)}
.btn-secondary{background:#fff;color:#0f172a;border:1px solid #d1d5db}
.btn-secondary:hover{background:#f8fafc}
.btn-ghost{background:rgba(255,255,255,.05);color:inherit;border:1px solid rgba(255,255,255,.1)}
.btn-ghost:hover{background:rgba(255,255,255,.08)}
.btn-danger{background:#ef4444;color:#fff}
.btn-success{background:#10b981;color:#fff}
.btn-sm{padding:.62rem .85rem;border-radius:12px;font-size:.88rem}
.input,textarea.select,select.input,textarea.input{width:100%;background:#fff;border:1px solid #d7deea;border-radius:16px;padding:.92rem 1rem;outline:none;transition:.2s;color:#0f172a}
textarea.input{min-height:120px;resize:vertical}
.input:focus,textarea.input:focus,select.input:focus{border-color:#c9952e;box-shadow:0 0 0 4px rgba(201,149,46,.14)}
.label{display:block;font-size:.82rem;font-weight:800;color:#334155;margin:0 0 .38rem}
.help{font-size:.78rem;color:#64748b;line-height:1.5}
.badge{display:inline-flex;align-items:center;gap:.45rem;padding:.48rem .78rem;border-radius:999px;background:rgba(201,149,46,.12);color:#a77012;font-size:.78rem;font-weight:800}
.status-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.38rem .72rem;border-radius:999px;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.status-pending{background:#fff7ed;color:#b45309;border:1px solid #fed7aa}
.status-confirmed{background:#ecfdf5;color:#047857;border:1px solid #a7f3d0}
.status-completed{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}
.status-canceled{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}
.status-rejected{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}
.metric{background:#fff;border:1px solid #e5e7eb;border-radius:22px;padding:1.25rem 1.35rem;box-shadow:0 10px 28px rgba(15,23,42,.04)}
.metric span{display:block;color:#64748b;font-weight:700;font-size:.85rem}
.metric b{display:block;font-size:2.1rem;font-weight:900;color:#0f2347;margin-top:.35rem}
.table{width:100%;border-collapse:collapse}
.table th{text-align:left;font-size:.78rem;color:#64748b;text-transform:uppercase;letter-spacing:.06em;padding:.85rem;border-bottom:1px solid #e7ebf3}
.table td{padding:1rem .85rem;border-bottom:1px solid #edf2f7;vertical-align:top}
.flash{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:1000;padding:.9rem 1.2rem;border-radius:16px;color:#fff;box-shadow:var(--shadow);font-weight:700}
.flash-success{background:#059669}.flash-error{background:#dc2626}

/* ===== Public template ===== */
body.public-body{background:var(--bg);color:var(--text)}
.public-wrap{background:var(--bg);color:var(--text)}
.public-header{position:sticky;top:0;z-index:60;background:rgba(7,7,7,.9);backdrop-filter:blur(18px);border-bottom:1px solid rgba(255,255,255,.06)}
.public-header-inner{height:88px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{width:42px;height:42px;border-radius:999px;border:2px solid var(--primary);display:grid;place-items:center;color:var(--primary);font-weight:800;font-family:'Playfair Display',serif}
.brand-name{font-family:'Playfair Display',serif;font-weight:800;letter-spacing:.02em;font-size:1.55rem}
.public-nav{display:flex;gap:34px;align-items:center}
.public-nav a{font-size:.9rem;text-transform:uppercase;letter-spacing:.14em;color:#fff;opacity:.92}
.public-nav a:hover{color:var(--primary)}
.mobile-toggle{display:none}
.hero{position:relative;min-height:calc(100vh - 88px);display:flex;align-items:center;background:radial-gradient(circle at 18% 12%, rgba(201,149,46,.12) 0, transparent 38%), linear-gradient(180deg, rgba(255,255,255,.02) 0, transparent 100%)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center;padding:86px 0 76px}
.hero-title{font-family:'Playfair Display',serif;font-size:clamp(4rem,9vw,7rem);font-weight:800;line-height:.95;letter-spacing:-.05em;margin:0;color:var(--text)}
.hero-title .accent{color:var(--primary)}
.hero-copy{font-size:1.18rem;line-height:1.8;color:#cbd5e1;max-width:55ch;margin-top:1.5rem}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:2.2rem}
.hero-visual{padding:34px;background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.06);border-radius:32px;box-shadow:0 20px 80px rgba(0,0,0,.28)}
.hero-card{background:var(--surface);border:1px solid rgba(255,255,255,.06);padding:24px;border-radius:26px}
.hero-card h3{font-family:'Playfair Display',serif;font-size:1.8rem;margin:0}
.hero-card p{color:#cbd5e1;line-height:1.7}
.stats-bar{background:#0f0f0f;border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;padding:26px 0;text-align:center}
.stat-value{font-family:'Playfair Display',serif;font-size:2.3rem;font-weight:800;color:var(--primary)}
.stat-label{font-size:.84rem;color:#98a2b3;text-transform:uppercase;letter-spacing:.12em}
.public-section{padding:92px 0}
.public-section.alt{background:rgba(255,255,255,.015)}
.section-head{text-align:center;max-width:780px;margin:0 auto 52px}
.section-head .section-subtitle{margin:18px auto 0;color:#9ca3af}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service-card{padding:30px;border-radius:26px;background:var(--surface);border:1px solid rgba(255,255,255,.06);transition:.25s;box-shadow:0 15px 40px rgba(0,0,0,.18);position:relative;overflow:hidden}
.service-card:before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent));transform:scaleX(0);transition:.3s}
.service-card:hover{transform:translateY(-4px);border-color:rgba(201,149,46,.38)}
.service-card:hover:before{transform:scaleX(1)}
.service-icon{width:58px;height:58px;border-radius:16px;background:rgba(201,149,46,.14);display:grid;place-items:center;color:var(--primary);font-size:1.6rem;margin-bottom:18px}
.service-card:hover .service-icon{background:var(--primary);color:#111}
.service-card h3{font-family:'Playfair Display',serif;font-size:2rem;line-height:1.05;margin:0 0 10px;color:var(--text)}
.service-card p{color:#b6beca;line-height:1.7;min-height:70px}
.service-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08);margin-top:16px}
.service-price{font-size:1.95rem;font-weight:900;color:var(--primary)}
.service-duration{color:#98a2b3;font-size:.92rem}
.schedule-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:start}
.schedule-panel{padding:28px;border-radius:28px;background:var(--surface);border:1px solid rgba(255,255,255,.06)}
.day-strip{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-top:18px}
.day-chip{border-radius:18px;padding:14px 10px;text-align:center;background:#121212;border:1px solid rgba(255,255,255,.06);cursor:pointer;transition:.2s}
.day-chip small{display:block;color:#98a2b3;text-transform:uppercase;letter-spacing:.12em;font-size:.68rem}
.day-chip strong{display:block;font-size:1.35rem;color:#fff;margin-top:4px}
.day-chip span{display:inline-flex;margin-top:8px;padding:.25rem .45rem;border-radius:999px;font-size:.65rem;font-weight:800}
.day-chip.available{background:rgba(16,185,129,.12);border-color:rgba(16,185,129,.24)}
.day-chip.almost{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.24)}
.day-chip.full{background:rgba(239,68,68,.10);border-color:rgba(239,68,68,.18);opacity:.5;cursor:not-allowed}
.day-chip.active{outline:2px solid var(--primary);transform:translateY(-2px)}
.day-chip.available span{background:rgba(16,185,129,.16);color:#6ee7b7}
.day-chip.almost span{background:rgba(245,158,11,.16);color:#fcd34d}
.day-chip.full span{background:rgba(239,68,68,.12);color:#fca5a5}
.slot-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:18px}
.slot-btn{padding:.92rem;border-radius:14px;background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.22);color:#6ee7b7;font-weight:800;cursor:pointer;transition:.2s}
.slot-btn:hover{background:rgba(16,185,129,.18)}
.slot-btn.active{background:var(--primary);border-color:var(--primary);color:#111}
.cart-summary{background:#101010;border:1px solid rgba(255,255,255,.07);border-radius:20px;padding:18px;margin:16px 0}
.cart-item{display:flex;justify-content:space-between;gap:12px;padding:.72rem 0;border-bottom:1px solid rgba(255,255,255,.06)}
.cart-item:last-child{border-bottom:none}
.form-dark .label{color:#dbe1e8}.form-dark .input,.form-dark textarea.input,.form-dark select.input{background:#161616;color:#fff;border-color:rgba(255,255,255,.08)}
.form-dark .input::placeholder, .form-dark textarea.input::placeholder{color:#6b7280}
.about-grid,.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:center}
.media-box{min-height:520px;border-radius:30px;background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.06);display:grid;place-items:center;color:#7b828f;padding:30px;text-align:center}
.feature-list{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:28px}
.feature-pill{display:flex;align-items:flex-start;gap:12px}
.feature-pill .dot{width:42px;height:42px;border-radius:999px;background:rgba(201,149,46,.14);display:grid;place-items:center;color:var(--primary);flex:0 0 auto}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonial-card{padding:28px;border-radius:26px;background:#090909;border:1px solid rgba(255,255,255,.07)}
.contact-list{display:grid;gap:20px;margin-top:20px}
.contact-item{display:flex;gap:14px;align-items:flex-start}
.contact-item .icon{width:42px;height:42px;border-radius:999px;background:rgba(201,149,46,.14);display:grid;place-items:center;color:var(--primary);flex:0 0 auto}
.public-footer{border-top:1px solid rgba(255,255,255,.05);padding:28px 0 40px;background:#090909}
.wa-float{position:fixed;right:22px;bottom:22px;width:62px;height:62px;border-radius:999px;background:#10b981;color:#fff;display:grid;place-items:center;z-index:70;box-shadow:0 18px 40px rgba(0,0,0,.3);font-weight:900}

/* ===== Admin ===== */
.admin-shell{min-height:100vh;display:grid;grid-template-columns:300px minmax(0,1fr);background:#f3f5f9}
.admin-sidebar{background:linear-gradient(180deg,#04102a 0%,#020817 100%);color:#fff;padding:22px;position:sticky;top:0;height:100vh}
.admin-brand{font-size:2rem;font-weight:900;letter-spacing:-.04em}
.admin-company{color:#8cb5ff;margin-top:4px;font-size:.92rem}
.admin-nav{display:grid;gap:8px;margin-top:28px}.admin-nav a{padding:14px 16px;border-radius:18px;color:#dbe7ff;font-weight:700;transition:.2s}.admin-nav a:hover{background:rgba(255,255,255,.08)}.admin-nav a.active{background:#fff;color:#071127}
.admin-main{padding:26px 28px 50px}
.admin-topbar{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:24px}
.admin-card{background:#fff;border:1px solid #e7ebf3;border-radius:28px;box-shadow:0 12px 35px rgba(15,23,42,.05)}
.admin-card.pad{padding:26px}
.toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.stack{display:grid;gap:22px}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.form-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.form-grid .full,.form-grid-3 .full{grid-column:1/-1}
.list-grid{display:grid;gap:14px}
.item-row{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;padding:20px;border:1px solid #e9eef7;border-radius:20px;background:#fbfdff}
.item-row h4{margin:0;font-size:1.15rem;color:#102348}.item-row p{margin:.35rem 0 0;color:#64748b;line-height:1.6}
.item-meta{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px;font-size:.88rem;color:#475569}
.tabs{display:flex;gap:8px;flex-wrap:wrap}.tab-btn{padding:.8rem 1rem;border-radius:14px;border:1px solid #d7deea;background:#fff;color:#0f172a;font-weight:800;cursor:pointer}.tab-btn.active{background:#0f2347;color:#fff;border-color:#0f2347}
.tab-panel{display:none}.tab-panel.active{display:block}
.calendar-board{display:grid;grid-template-columns:repeat(7,1fr);gap:12px}
.calendar-col{background:#fff;border:1px solid #e7ebf3;border-radius:22px;padding:16px;min-height:160px}
.calendar-col h5{margin:0 0 12px;font-size:.9rem;text-transform:uppercase;letter-spacing:.06em;color:#64748b}
.appt-pill{display:block;padding:10px 12px;border-radius:14px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;font-size:.83rem;font-weight:700;margin-bottom:8px}
.appt-card{padding:18px;border:1px solid #e7ebf3;border-radius:22px;background:#fff}
.appt-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.preview-box{border-radius:30px;background:#09111f;padding:18px;border:1px solid #12233f;color:#fff;overflow:hidden}
.preview-frame{background:var(--preview-bg,#080808);color:var(--preview-text,#ffffff);border-radius:24px;min-height:560px;padding:0;border:1px solid rgba(255,255,255,.06);overflow:hidden}
.preview-nav{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid rgba(255,255,255,.07)}
.preview-hero{padding:42px 24px;text-align:center;background:radial-gradient(circle at 20% 20%, rgba(201,149,46,.18) 0, transparent 35%)}
.preview-hero h3{font-family:'Playfair Display',serif;font-size:2.6rem;line-height:1;margin:12px 0}
.preview-chip{display:inline-flex;padding:.34rem .65rem;border-radius:999px;background:rgba(255,255,255,.08);font-size:.72rem;text-transform:uppercase;letter-spacing:.18em}
.preview-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:0 24px 24px}
.preview-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:14px;text-align:left}
.preview-btn{display:inline-flex;padding:.85rem 1rem;border-radius:14px;background:var(--preview-button,#c9952e);color:var(--preview-button-text,#111);font-weight:800}
.theme-preset{display:flex;gap:8px;flex-wrap:wrap}.theme-preset button{padding:.72rem .9rem;border-radius:14px;border:1px solid #d7deea;background:#fff;font-weight:800;cursor:pointer}
.notice-banner{padding:18px 20px;border-radius:20px;border:1px solid #f5d99b;background:#fffbeb;color:#92400e}
.notice-danger{border-color:#fca5a5;background:#fef2f2;color:#991b1b}
.modal{position:fixed;inset:0;background:rgba(2,6,23,.62);display:none;align-items:center;justify-content:center;padding:20px;z-index:80}
.modal.open{display:flex}.modal-card{width:min(760px,100%);max-height:90vh;overflow:auto;background:#fff;border-radius:28px;padding:26px;border:1px solid #e5e7eb;box-shadow:0 22px 60px rgba(15,23,42,.25)}
.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}
.close-btn{width:40px;height:40px;border-radius:999px;border:1px solid #d7deea;background:#fff;cursor:pointer}
.switch{display:flex;align-items:center;gap:.55rem;font-weight:700;color:#334155}
.switch input{width:18px;height:18px}
.empty-state{padding:28px;text-align:center;color:#64748b}

@media (max-width: 1100px){
  .service-grid,.testimonials-grid,.feature-list,.stats-grid,.schedule-grid,.about-grid,.contact-grid,.form-grid,.form-grid-3,.preview-cards,.admin-shell{grid-template-columns:1fr}
  .hero-grid{grid-template-columns:1fr;gap:28px;min-height:auto}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .day-strip{grid-template-columns:repeat(4,1fr)}
  .slot-grid{grid-template-columns:repeat(3,1fr)}
  .admin-shell{display:block}.admin-sidebar{position:static;height:auto}.admin-main{padding:20px}
}
@media (max-width: 860px){
  .public-nav{display:none}.mobile-toggle{display:inline-flex}.hero-title{font-size:3.3rem}.brand-name{font-size:1.2rem}.public-header-inner{height:76px}.public-section{padding:74px 0}.service-card h3{font-size:1.65rem}.slot-grid{grid-template-columns:repeat(2,1fr)}.day-strip{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 640px){
  .container{width:min(100% - 20px,1200px)}
  .btn-primary,.btn-secondary,.btn-ghost{width:100%}
  .hero-actions{display:grid;grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr;gap:16px}
  .service-grid,.testimonials-grid{grid-template-columns:1fr}
  .public-section{padding:66px 0}
  .page-title{font-size:2rem}
  .admin-topbar{flex-direction:column}
  .item-row{flex-direction:column}
}
