:root{
  --bg: #f2f4f7;
  --surface: #ffffff;
  --card: #ffffff;
  --card-2: #f3f7fa;
  --text: #0f1419;
  --muted: #6b7280;
  --primary: #0284c7;
  --primary-2: #0ea5e9;
  --accent: #059669;
  --ok: #10b981;
  --warn: #f59e0b;
  --danger: #ef4444;
  --ring: rgba(2,132,199,.2);
  --radius: 12px;
  --shadow: 0 10px 35px rgba(0,0,0,.1);
  --shadow-soft: 0 4px 12px rgba(0,0,0,.06);
  --container: 1200px;
  --gap: 16px;
  --font-heading: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body: 'Sora', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif;
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --tab-height: 64px;
  color-scheme: light only;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  margin:0;
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  padding-bottom: calc(var(--tab-height) + var(--safe-bottom));
  overscroll-behavior: none;
}
a{color:inherit; text-decoration:none}
.container{
  max-width: var(--container);
  padding: 0 18px;
  margin: 0 auto;
}
.sr-only{
  position:absolute!important;
  height:1px;width:1px;
  overflow:hidden;
  clip:rect(1px,1px,1px,1px);
  white-space:nowrap;
}

/* Header - más compacto como app */
.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 10px 0;
}
.brand{
  display:flex;
  align-items:center;
  gap: 10px;
  text-decoration:none;
}
.brand-mark{
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display:grid;
  place-items:center;
  background: linear-gradient(135deg, #0284c7, #0ea5e9);
  color: #ffffff;
  font-weight: 900;
  font-size: 17px;
  box-shadow: 0 3px 10px rgba(2,132,199,.25);
}
.brand-logo{
  width: 38px;
  height: 38px;
  border-radius: 10px;
  object-fit: contain;
  flex-shrink:0;
}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-top{font-size:15px; font-weight:700}
.brand-sub{font-size: 11px; color: var(--muted)}
.site-nav{
  display:flex;
  gap: 10px;
  align-items:center;
}
.site-nav a{
  padding: 7px 12px;
  border-radius: 8px;
  color: var(--muted);
  transition: .15s ease;
  font-weight: 500;
  font-size: 13px;
}
.site-nav a:hover{background: rgba(2,132,199,.1); color: var(--primary)}
.nav-toggle{
  display:none;
  width: 38px; height: 38px;
  border-radius: 10px;
  border: 1px solid rgba(29,26,22,.12);
  background: rgba(255,255,255,.6);
  color: var(--text);
  padding: 9px;
}
.nav-toggle span{
  display:block;
  height: 2px;
  background: rgba(29,26,22,.8);
  margin: 4px 0;
  border-radius: 2px;
}

/* Hero - más limpio */
.hero{
  padding: 48px 0 40px;
  background:
    linear-gradient(135deg, rgba(2,132,199,.1), rgba(16,182,129,.06)),
    var(--hero-bg) center/cover no-repeat;
  border-bottom: 1px solid rgba(0,0,0,.04);
  position: relative;
}
.hero-inner{display:flex; align-items:flex-end;}
.hero-card{
  width: min(760px, 100%);
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,.1);
  padding: 28px 28px 32px;
  backdrop-filter: blur(2px);
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(2,132,199,.2);
  background: linear-gradient(135deg, rgba(2,132,199,.08), rgba(2,132,199,.04));
  color: #0284c7;
  font-size: 11px;
  margin: 0 0 10px;
  font-weight: 600;
}
h1,h2,h3,h4{
  font-family: var(--font-heading);
  letter-spacing: -0.02em;
  font-weight: 700;
}
h1{margin: 0 0 10px; font-size: clamp(28px, 4vw, 44px); color: var(--text); line-height: 1.15}
.lead{margin: 0 0 14px; color: var(--muted); font-size: 15px; line-height: 1.7}

.search-row{
  display:flex;
  gap: 8px;
  align-items: stretch;
  flex-wrap: wrap;
  margin-top: 10px;
}
.search-row input[type="search"]{
  flex: 1 1 240px;
  min-width: 180px;
  height: 46px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.1);
  background: rgba(255,255,255,.98);
  color: var(--text);
  padding: 0 16px;
  outline: none;
  font-size: 14px;
  transition: all .2s ease;
  font-family: var(--font-body);
}
.search-row input[type="search"]:focus{box-shadow: 0 0 0 3px var(--ring); border-color: var(--primary)}
.search-row input[type="search"]::placeholder{color: #9ca3af}

.search-results{
  margin-top: 10px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.06);
  background: #ffffff;
  box-shadow: 0 8px 30px rgba(0,0,0,.1);
  max-height: 340px;
  overflow-y: auto;
  animation: fadeUp .2s ease;
}
.search-item{
  display:flex;
  align-items:center;
  gap: 12px;
  padding: 10px 14px;
  cursor:pointer;
  transition: background .15s ease;
  border-bottom: 1px solid rgba(0,0,0,.04);
}
.search-item:last-child{border-bottom:none}
.search-item:active{background: rgba(2,132,199,.08)}
.search-item-img{
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: #e2e8f0 center/cover no-repeat;
  flex-shrink: 0;
}
.search-item-info{display:flex; flex-direction:column; gap: 2px; min-width:0}
.search-item-info strong{font-size: 14px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.search-empty{padding: 20px; text-align:center; color: var(--muted); font-size: 14px}

.hero-actions{display:flex; gap: 8px; margin-top: 14px; flex-wrap: wrap}
.btn-ig{
  background: linear-gradient(135deg, #f58529, #dd2a7b, #8134af);
  border: none;
  color: #ffffff;
  font-weight: 600;
  font-size: 13px;
}
.btn-ig:hover{box-shadow: 0 4px 20px rgba(221,42,123,.4); color: #ffffff}
.btn-ig:active{opacity:.9}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 6px;
  padding: 0 16px;
  height: 46px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.1);
  background: rgba(255,255,255,.95);
  text-decoration:none;
  cursor:pointer;
  transition: all .2s ease;
  color: var(--text);
  font-weight: 500;
  font-family: var(--font-body);
  font-size: 14px;
  -webkit-user-select:none;
  user-select:none;
}
.btn:active{transform: scale(.97); opacity:.85}
.btn-primary{
  background: linear-gradient(135deg, #0284c7, #0ea5e9);
  border-color: rgba(2,132,199,.4);
  color: #ffffff;
  font-weight: 600;
}
.btn-primary:active{opacity:.9}
.section{padding: 36px 0}
.section-head{margin-bottom: 18px}
.section-head h2{font-size: 24px}
.section-head p{font-size: 14px}
h2{margin:0; font-size: 22px}
.muted{color: var(--muted)}
.small{font-size: 12px}

/* Category Grid - nativo */
.category-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 14px;
}
.category-card{
  background: #ffffff;
  border-radius: 18px;
  padding: 24px 14px 20px;
  text-align: center;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
  border: 1px solid rgba(0,0,0,.04);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap: 8px;
  transition: all .25s ease;
  animation: cardIn .4s ease backwards;
  animation-delay: var(--delay, 0s);
  -webkit-user-select:none;
  user-select:none;
}
@keyframes cardIn{
  from{opacity:0; transform:translateY(12px) scale(.97)}
  to{opacity:1; transform:translateY(0) scale(1)}
}
.category-card:active{transform: scale(.95); opacity:.8}
.category-card .cat-icon{
  width: 56px;
  height: 56px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  background: linear-gradient(135deg, #f0f7ff, #e8f4fd);
  color: var(--primary);
  flex-shrink: 0;
  transition: all .25s ease;
}
.category-card .cat-icon svg{width: 26px; height: 26px}
.category-card h3{margin:0; font-size: 13px; font-weight:600; color:var(--text); line-height:1.3}
.category-card p{margin:0; color: var(--muted); font-size: 11px; font-weight:400}
.category-card.highlight{
  border-color: #f59e0b;
  background: linear-gradient(135deg, #fffbeb, #fff);
  box-shadow: 0 4px 16px rgba(245,158,11,.1);
  position:relative;
}
.category-card.highlight::after{
  content:"";
  position:absolute;
  top:0; left:0; right:0;
  height: 3px;
  background: linear-gradient(90deg, #f59e0b, #f97316);
  border-radius: 18px 18px 0 0;
}
.category-card.highlight .cat-icon{
  background: linear-gradient(135deg, #fef3c7, #fde68a);
  color: #d97706;
}

/* Modal - Bottom Sheet nativo */
.modal{
  position: fixed; inset: 0;
  display:none;
  align-items:flex-end;
  justify-content:center;
  z-index: 80;
}
.modal[aria-hidden="false"]{display:flex}
.modal-backdrop{
  position:fixed; inset:0;
  background: rgba(0,0,0,.4);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  animation: fadeIn .25s ease;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-card{
  position:relative;
  width: 100%;
  max-width: 680px;
  max-height: 85vh;
  border-radius: 20px 20px 0 0;
  overflow:hidden;
  background: var(--bg);
  box-shadow: 0 -10px 40px rgba(0,0,0,.15);
  display:flex;
  flex-direction:column;
  animation: sheetUp .4s cubic-bezier(.32,.72,0,1);
}
@keyframes sheetUp{
  from{transform:translateY(100%)}
  to{transform:translateY(0)}
}
.modal-grabber{
  display:flex;
  justify-content:center;
  padding: 8px 0 4px;
  flex-shrink:0;
  background: var(--surface);
}
.modal-grabber span{
  width: 36px;
  height: 4px;
  border-radius: 2px;
  background: rgba(0,0,0,.15);
}
.modal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 4px 18px 14px;
  background: var(--surface);
  flex-shrink:0;
}
.modal-head h3{margin:0; font-size: 17px; font-weight:700}
.modal-grid{
  padding: 8px 14px 20px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  flex: 1;
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 10px;
  align-content: start;
}
.modal-card-lg{max-width: 560px}
.detail-body{
  padding: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  flex: 1;
  background: var(--surface);
}
.detail-hero{
  width:100%;
  height: 200px;
  background: #e2e8f0 center/cover no-repeat;
  flex-shrink:0;
}
.detail-info{
  padding: 18px 18px 22px;
  display:flex;
  flex-direction:column;
  gap: 8px;
}
.detail-info h2{margin:0; font-size: 18px; font-weight:700}
.detail-category{
  font-size: 12px;
  color: var(--primary);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.4px;
}
.detail-row{
  display:flex;
  align-items:center;
  gap: 8px;
  font-size: 14px;
  color: var(--text);
  padding: 3px 0;
}
.detail-row .label{color: var(--muted); min-width:70px}
.detail-actions{
  display:flex;
  gap: 8px;
  flex-wrap:wrap;
  margin-top: 4px;
  padding-top: 12px;
  border-top: 1px solid rgba(0,0,0,.06);
}

/* Provider Cards - iOS style */
.s-card{
  border-radius: 14px;
  overflow:hidden;
  border: 1px solid rgba(0,0,0,.06);
  background: #ffffff;
  box-shadow: 0 2px 8px rgba(0,0,0,.04);
  display:flex;
  flex-direction:column;
  cursor:pointer;
  transition: transform .2s ease, box-shadow .2s ease;
  min-height: 260px;
}
.s-card:active{transform: scale(.97); opacity:.9}
.s-card-media{
  width: 100%;
  height: 130px;
  background: #e2e8f0 center/cover no-repeat;
  flex-shrink:0;
}
.s-card-body{
  padding: 12px 14px 14px;
  display:flex;
  flex-direction:column;
  gap: 4px;
  flex:1;
}
.s-card-body h4{margin:0; font-size: 14px; font-weight:700; line-height:1.3; color:var(--text)}
.s-card-addr{font-size: 12px; color: var(--muted); line-height:1.4}
.s-card-detail{margin:0; font-size: 12px; color: var(--muted); line-height:1.5; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden}
.s-card-actions{display:flex; gap: 5px; flex-wrap:wrap; margin-top:auto; padding-top:8px}
.s-card-actions .s-btn{
  display:inline-flex;
  align-items:center;
  gap: 4px;
  padding: 0 10px;
  height: 30px;
  border-radius: 8px;
  font-size: 12px;
  font-weight:600;
  text-decoration:none;
  cursor:pointer;
  transition: all .15s ease;
  font-family: var(--font-body);
  border: none;
}
.s-btn:active{transform: scale(.95)}
.s-btn-maps{background: #eff6ff; color: #0284c7}
.s-btn-wa{background: #f0fdf4; color: #166534}
.s-btn-tel{background: #fef2f2; color: #991b1b}
.s-booking{
  display:inline-flex;
  align-items:center;
  gap: 4px;
  padding: 0 10px;
  height: 30px;
  border-radius: 8px;
  background: rgba(2,132,199,.08);
  color: var(--primary);
  font-size: 11px;
  font-weight:700;
}
@keyframes fadeUp{
  from{opacity:0; transform:translateY(12px)}
  to{opacity:1; transform:translateY(0)}
}
.btn-sm{height: 34px; padding: 0 12px; border-radius: 10px; font-size: 12px}

/* Gallery */
.gallery-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 12px;
}
.gallery-item{
  border-radius: 14px;
  overflow:hidden;
  position:relative;
  aspect-ratio: 4/3;
  background: #e2e8f0;
  cursor:pointer;
  transition: transform .25s ease;
}
.gallery-item:active{transform: scale(.97)}
.gallery-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.gallery-item .gallery-label{
  position:absolute;
  bottom:0;left:0;right:0;
  padding: 30px 14px 12px;
  background: linear-gradient(transparent, rgba(0,0,0,.55));
  color: #fff;
  font-size: 13px;
  font-weight:600;
}

/* Footer */
.site-footer{
  border-top: 1px solid rgba(0,0,0,.04);
  padding: 24px 0 28px;
  background: rgba(255,255,255,.7);
  margin-top: 40px;
}
.footer-inner{display:flex; flex-direction:column; gap: 4px; align-items:center; text-align:center}
.footer-inner p{margin:0; font-size: 13px}
.footer-links{display:flex; gap: 8px; margin-top: 2px}

/* Bottom Tab Bar */
.tab-bar{
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: var(--tab-height);
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-top: 1px solid rgba(0,0,0,.06);
  display:flex;
  align-items:center;
  justify-content:space-around;
  padding: 0 8px;
  padding-bottom: var(--safe-bottom);
  z-index: 70;
}
.tab-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap: 2px;
  padding: 4px 12px;
  border-radius: 10px;
  color: var(--muted);
  transition: color .15s ease;
  font-size: 10px;
  font-weight: 500;
  text-decoration:none;
  -webkit-user-select:none;
  user-select:none;
  border: none;
  background: none;
  cursor:pointer;
  font-family: var(--font-body);
}
.tab-item svg{width: 24px; height: 24px}
.tab-item.tab-active{color: var(--primary)}
.tab-item:active{opacity:.7}

.safe-area-bottom{
  display:none;
}

/* Tablet */
@media (min-width: 768px){
  body{padding-bottom:0}
  .tab-bar{display:none}
  .site-header .header-inner{padding: 14px 0}
  .hero{padding: 64px 0 48px}
  .hero-card{padding: 32px 36px 36px}
  .modal{align-items:center; padding: 22px}
  .modal-card{
    max-height: 80vh;
    border-radius: 16px;
    animation: modalIn .25s ease;
    width: min(800px, 100%);
    box-shadow: 0 25px 80px rgba(0,0,0,.2);
  }
  @keyframes modalIn{
    from{opacity:0; transform:scale(.95) translateY(10px)}
    to{opacity:1; transform:scale(1) translateY(0)}
  }
  .modal-grabber{display:none}
  .modal-head{padding: 16px 18px; border-bottom: 1px solid rgba(0,0,0,.06)}
  .modal-grid{padding: 14px 18px 18px; gap: 12px}
  .modal-card-lg{width: min(560px, 100%)}
  .category-grid{grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 18px}
  .section{padding: 44px 0}
  .section-head h2{font-size: 28px}
}

/* Desktop adjustments */
@media (min-width: 1024px){
  .category-grid{grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 20px}
  .category-card{padding: 28px 16px 24px}
  .category-card .cat-icon{width: 64px; height: 64px}
  .category-card .cat-icon svg{width: 30px; height: 30px}
  .category-card h3{font-size: 15px}
}

/* Mobile fine-tune */
@media (max-width: 767px){
  .site-nav{display:none}
  .nav-toggle{display:block}
  .site-nav.open{
    display:flex;
    position:absolute;
    top: 58px;
    right: 14px;
    flex-direction:column;
    gap: 6px;
    background: rgba(255,255,255,.96);
    border: 1px solid rgba(0,0,0,.1);
    border-radius: 16px;
    padding: 8px;
    box-shadow: var(--shadow-soft);
    min-width: 180px;
  }
  .category-grid{grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px}
  .category-card{padding: 20px 12px 16px}
  .category-card .cat-icon{width: 48px; height: 48px; border-radius: 14px}
  .category-card .cat-icon svg{width: 22px; height: 22px}
  .category-card h3{font-size: 12px}
  .category-card p{font-size: 10px}
  .category-card.highlight::after{height: 3px; border-radius: 18px 18px 0 0}
  .modal-card{max-height: 92vh}
  .modal-grid{grid-template-columns: 1fr; padding: 6px 14px 16px}
  .s-card-media{height: 120px}
  .s-card{min-height: 240px}
  .modal-backdrop{-webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px)}
}

/* Small phones */
@media (max-width: 420px){
  .category-grid{grid-template-columns: repeat(2, 1fr); gap: 8px}
  .category-card{padding: 16px 10px 14px}
  .category-card .cat-icon{width: 42px; height: 42px; border-radius: 12px}
  .category-card .cat-icon svg{width: 20px; height: 20px}
  .hero-card{padding: 20px 18px 24px; border-radius: 14px}
  .hero{padding: 32px 0 28px}
  h1{font-size: 26px}
  .modal-card{border-radius: 16px 16px 0 0}
}

/* Admin Panel Styles - Responsive */
.admin-panel{
  display:flex;
  min-height: 100vh;
  background: var(--bg);
}
.admin-sidebar{
  width: 240px;
  background: rgba(255,255,255,.98);
  border-right: 1px solid rgba(0,0,0,.06);
  overflow-y: auto;
  position: sticky;
  top: 0;
  height: 100vh;
  flex-shrink:0;
}
.admin-header{
  padding: 16px 16px;
  border-bottom: 1px solid rgba(0,0,0,.06);
  display:flex;
  align-items:center;
  gap: 8px;
}
.admin-header h2{margin:0; font-size:18px; color:var(--text); flex:1}
.admin-header .btn:last-child{margin-left:auto}
.admin-toggle-nav{
  display:none;
  width:36px;height:36px;
  border:none;
  background:transparent;
  color:var(--text);
  cursor:pointer;
  border-radius:8px;
  padding:6px;
  flex-shrink:0;
}
.admin-toggle-nav svg{width:24px;height:24px;display:block}
.admin-toggle-nav:hover{background:rgba(0,0,0,.05)}
.admin-toggle-nav:active{background:rgba(0,0,0,.08)}
.admin-nav{display:flex;flex-direction:column;gap:4px;padding:12px}
.admin-nav button{
  width:100%;text-align:left;padding:12px 14px;border-radius:8px;
  border:1px solid transparent;background:transparent;color:var(--muted);
  cursor:pointer;transition:.15s ease;font-size:13px;font-weight:500;
  font-family:var(--font-body);
}
.admin-nav button:hover{background:rgba(2,132,199,.08);color:var(--primary)}
.admin-nav button.active{background:rgba(2,132,199,.15);border-color:var(--primary);color:var(--primary)}
.admin-main{flex:1;padding:24px;overflow-y:auto;min-width:0}
.admin-view{display:none}
.admin-view.active{display:block}
.admin-title{margin:0 0 20px;font-size:26px;color:var(--text)}
.admin-toolbar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}
.admin-toolbar .btn{border:1px solid rgba(2,132,199,.3);background:rgba(255,255,255,.95);color:var(--primary)}
.admin-toolbar .btn-primary{background:linear-gradient(135deg,#0284c7,#0ea5e9);color:white;border-color:var(--primary)}
.admin-table-wrap{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  border-radius:10px;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:var(--shadow-soft);
}
.admin-table{
  width:100%;
  border-collapse:collapse;
  background:rgba(255,255,255,.98);
  min-width:600px;
}
.admin-table th{
  padding:12px 14px;
  text-align:left;
  background:rgba(2,132,199,.06);
  border-bottom:1px solid rgba(0,0,0,.08);
  font-weight:600;
  color:var(--text);
  font-size:13px;
  white-space:nowrap;
}
.admin-table td{
  padding:12px 14px;
  border-bottom:1px solid rgba(0,0,0,.04);
  color:var(--text);
  font-size:14px;
}
.admin-table tr:active{background:rgba(2,132,199,.04)}
.admin-table .actions{display:flex;gap:6px;flex-wrap:wrap}
.admin-table .btn-sm{height:32px;padding:0 10px;font-size:12px;border-radius:6px;white-space:nowrap}
.form-group{margin-bottom:16px;display:flex;flex-direction:column;gap:6px}
.form-group label{font-weight:600;font-size:13px;color:var(--text)}
.form-group input,.form-group select,.form-group textarea{
  padding:10px 12px;border-radius:8px;border:1px solid rgba(0,0,0,.12);
  background:rgba(255,255,255,.98);color:var(--text);font-family:inherit;font-size:14px;transition:.15s ease;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;box-shadow:0 0 0 3px var(--ring);border-color:var(--primary)
}
.form-group textarea{resize:vertical;min-height:100px}
.admin-form{
  background:rgba(255,255,255,.98);
  border:1px solid rgba(0,0,0,.08);
  border-radius:10px;
  padding:24px;
  max-width:600px;
  box-shadow:var(--shadow-soft);
}
.form-actions{display:flex;gap:12px;margin-top:20px}
.form-actions .btn{flex:1}
.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);padding:20px}
.login-card{
  background:rgba(255,255,255,.98);
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  padding:36px 32px;
  max-width:400px;
  width:100%;
  box-shadow:var(--shadow);
}
.login-card h1{margin:0 0 8px;font-size:26px;text-align:center}
.login-card p{text-align:center;color:var(--muted);margin:0 0 20px;font-size:14px}
.btn-danger{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.3);color:#dc2626}
.btn-danger:hover{background:rgba(239,68,68,.15)}
.btn-danger:active{background:rgba(239,68,68,.2)}
.btn-accent{background:rgba(16,182,129,.1);border-color:rgba(16,182,129,.3);color:var(--accent)}
.btn-accent:hover{background:rgba(16,182,129,.15)}
.btn-accent:active{background:rgba(16,182,129,.2)}
.badge-danger{background:rgba(239,68,68,.1);color:#dc2626;border-color:rgba(239,68,68,.3)}
.admin-card{
  background:rgba(255,255,255,.98);
  border:1px solid rgba(0,0,0,.08);
  border-radius:10px;
  padding:18px;
  box-shadow:var(--shadow-soft);
  margin-bottom:14px;
}

/* Admin responsive */
@media (max-width: 900px){
  .admin-sidebar{width:200px}
  .admin-main{padding:20px}
  .admin-title{font-size:22px}
}
@media (max-width: 767px){
  body.admin-page{padding-bottom:0}
  .admin-panel{flex-direction:column}
  .admin-sidebar{
    width:100%;
    height:auto;
    position:sticky;
    top:0;
    z-index:50;
    border-right:none;
    border-bottom:1px solid rgba(0,0,0,.06);
  }
  .admin-header{padding:12px 14px; min-height:52px}
  .admin-toggle-nav{display:block}
  .admin-nav{
    flex-direction:column;
    gap:2px;
    padding:0 12px 12px;
    max-height:0;
    overflow:hidden;
    transition:max-height .3s ease, padding .3s ease;
  }
  .admin-nav.open{
    max-height:300px;
    padding:4px 12px 12px;
  }
  .admin-nav button{
    white-space:nowrap;
    text-align:left;
    padding:12px 14px;
    font-size:13px;
  }
  .admin-main{padding:16px;min-height:calc(100vh - 120px)}
  .admin-title{font-size:20px;margin-bottom:16px}
  .admin-toolbar{gap:8px}
  .admin-toolbar .btn{font-size:12px;height:40px;padding:0 12px}
  .admin-toolbar input[type="search"]{font-size:16px;height:40px;min-width:140px}
  .admin-table-wrap{border-radius:8px;margin:0 -8px;border-left:none;border-right:none}
  .admin-table th{padding:10px 8px;font-size:12px}
  .admin-table td{padding:10px 8px;font-size:13px}
  .admin-table .actions{gap:4px;flex-direction:column}
  .admin-table .actions .btn-sm{width:100%;justify-content:center;height:32px;padding:0 6px;font-size:12px}
  .admin-form{padding:18px;max-width:100%}
  .form-group input,.form-group select,.form-group textarea{font-size:16px;padding:12px}
  .form-actions{flex-direction:column}
  .form-actions .btn{height:44px;font-size:14px}
  .login-card{padding:28px 24px;border-radius:12px}
  .login-card h1{font-size:24px}
  .admin-card{padding:14px}
  .admin-card h3{font-size:15px}
}
@media (max-width: 480px){
  .admin-main{padding:10px}
  .admin-title{font-size:18px;margin-bottom:12px}
  .admin-toolbar{gap:6px}
  .admin-toolbar .btn{font-size:11px;height:36px;padding:0 10px}
  .admin-toolbar input[type="search"]{width:100%;min-width:0}
  .admin-table{min-width:450px}
  .admin-table-wrap{margin:0 -6px}
  .admin-table th{padding:8px 6px;font-size:11px}
  .admin-table td{padding:8px 6px;font-size:12px}
  .admin-table .actions .btn-sm{height:28px;font-size:11px;padding:0 4px}
  .admin-form{padding:14px}
  .login-card{padding:24px 18px}
  .category-card.highlight .cat-icon{width:38px;height:38px}
}
