:root{
  --bg:#0b1220;--surface:#0f172a;--surface-2:#111c33;--text:#e8eef7;--muted:#9aa7bd;
  --gold:#c8a96a;--gold-2:#e2c98c;--line:#1f2a44;--ok:#1f9d6a;--err:#c2410c;
  --radius:14px;--shadow:0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}html,body{margin:0;padding:0}
body{font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.55}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;letter-spacing:.2px;margin:0 0 .5em}
h1{font-size:clamp(2rem,5vw,3.4rem);line-height:1.1}
h2{font-size:clamp(1.6rem,3vw,2.2rem)}
.container{width:min(1140px,92%);margin:0 auto}
.muted{color:var(--muted)}
a{color:var(--gold-2);text-decoration:none}a:hover{color:var(--gold)}

.nav{position:sticky;top:0;z-index:30;background:rgba(11,18,32,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:10px;color:var(--text);font-weight:600}
.brand b{color:var(--gold)}
.brand-mark{width:34px;height:34px;border-radius:8px;background:linear-gradient(135deg,var(--gold),#8b6a2f);color:#0b1220;display:grid;place-items:center;font-family:Georgia,serif;font-weight:700}
.nav nav{display:flex;gap:18px;align-items:center}
.nav nav a{color:var(--text);font-size:.95rem}
.nav nav a.cta{background:var(--gold);color:#0b1220;padding:8px 14px;border-radius:999px;font-weight:600}

.hero{padding:64px 0;background:radial-gradient(1200px 500px at 80% -10%,rgba(200,169,106,.18),transparent 60%),linear-gradient(180deg,#0b1220 0%,#0c1426 100%)}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.kicker{display:inline-block;color:var(--gold);letter-spacing:.18em;text-transform:uppercase;font-size:.78rem;margin-bottom:14px}
.lead{color:#cdd6e6;font-size:1.08rem;max-width:52ch}
.hero-actions{display:flex;gap:12px;margin-top:22px;flex-wrap:wrap}
.btn{display:inline-block;padding:12px 20px;border-radius:999px;font-weight:600;border:1px solid transparent;cursor:pointer;font-size:.98rem;transition:transform .15s ease, background .2s}
.btn-primary{background:var(--gold);color:#0b1220}.btn-primary:hover{background:var(--gold-2)}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--line)}.btn-ghost:hover{border-color:var(--gold)}
.hero-img{height:100%;min-height:340px;border-radius:var(--radius);background:url('/assets/fachada.jpg') center/cover no-repeat;box-shadow:var(--shadow);border:1px solid var(--line)}

.section{padding:72px 0}.section.alt{background:var(--surface)}
.grid{display:grid;gap:18px;margin-top:24px}
.services{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.service{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:22px;transition:border-color .2s}
.service:hover{border-color:var(--gold)}
.service h3{color:var(--text);font-size:1.15rem;margin:0 0 6px}
.service .price{color:var(--gold);font-weight:700;margin-top:10px;display:block}
.service .dur{color:var(--muted);font-size:.9rem}

.gallery{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.gallery img{width:100%;height:220px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--line)}

.two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center}
.two-col img{width:100%;border-radius:var(--radius);border:1px solid var(--line)}

.card{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.form{display:flex;flex-direction:column;gap:14px;margin-top:18px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form label{display:flex;flex-direction:column;gap:6px;color:#cdd6e6;font-size:.92rem}
.form input,.form select,.form textarea{background:#0a1326;border:1px solid var(--line);color:var(--text);border-radius:10px;padding:11px 12px;font-size:1rem;font-family:inherit}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--gold)}
.form-msg{margin:0;min-height:1.2em;font-size:.95rem}
.form-msg.ok{color:#7ee0b0}.form-msg.err{color:#ffb38a}

.footer{background:#070d1a;border-top:1px solid var(--line);padding:50px 0 24px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.footer h4{color:var(--gold);font-family:inherit;font-size:.95rem;letter-spacing:.12em;text-transform:uppercase}
.hours,.contacts{list-style:none;margin:0;padding:0}
.hours li{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px dashed var(--line);color:#cdd6e6}
.contacts li{padding:5px 0}
.copyright{margin-top:30px;color:var(--muted);font-size:.85rem;text-align:center}

/* admin */
.admin-shell{min-height:100vh;background:var(--bg);padding:40px 0}
.table{width:100%;border-collapse:collapse;margin-top:16px;background:var(--surface-2);border-radius:var(--radius);overflow:hidden}
.table th,.table td{padding:12px 14px;border-bottom:1px solid var(--line);text-align:left;font-size:.94rem}
.table th{background:#0a1326;color:var(--gold);font-weight:600;text-transform:uppercase;font-size:.78rem;letter-spacing:.1em}
.badge{display:inline-block;padding:3px 9px;border-radius:999px;font-size:.78rem;font-weight:600}
.badge.pending{background:#3b2e10;color:#e6c97a}
.badge.confirmed{background:#103a26;color:#7ee0b0}
.badge.cancelled{background:#3a1414;color:#ffb38a}
.badge.done{background:#102a3a;color:#8fc7ff}
.row-actions{display:flex;gap:6px;flex-wrap:wrap}
.btn.sm{padding:6px 10px;font-size:.82rem}

@media (max-width:820px){
  .hero-inner,.two-col,.footer-grid{grid-template-columns:1fr}
  .hero-img{min-height:240px}
  .form .row{grid-template-columns:1fr}
  .nav nav{gap:10px}.nav nav a:not(.cta){display:none}
}
