/* ===== HAMPSHIREWEB – CLEAN WHITE MINIMAL ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --black:#0f0f0f;
  --ink:#1a1a1a;
  --ink-2:#3d3d3d;
  --muted:#6b7280;
  --border:#e5e7eb;
  --border-2:#d1d5db;
  --bg:#ffffff;
  --bg-2:#f9fafb;
  --bg-3:#f3f4f6;
  --accent:#0066ff;
  --accent-dark:#0052cc;
  --accent-light:#eff6ff;
  --success:#16a34a;
  --error:#dc2626;
  --radius:8px;
  --radius-lg:12px;
  --shadow:0 1px 3px rgba(0,0,0,0.1),0 1px 2px rgba(0,0,0,0.06);
  --shadow-md:0 4px 6px -1px rgba(0,0,0,0.1),0 2px 4px -1px rgba(0,0,0,0.06);
  --shadow-lg:0 10px 15px -3px rgba(0,0,0,0.1),0 4px 6px -2px rgba(0,0,0,0.05);
}
html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden}
body{font-family:'Inter',sans-serif;color:var(--ink);background:var(--bg);line-height:1.6;overflow-x:hidden}

/* UTILS */
.container{max-width:1140px;margin:0 auto;padding:0 1.5rem}
.section-tag{display:inline-block;font-size:0.72rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--accent);background:var(--accent-light);padding:0.3rem 0.8rem;border-radius:999px;margin-bottom:1rem}
.section-head{text-align:center;margin-bottom:3.5rem}
.section-head h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,3.5vw,2.8rem);font-weight:600;color:var(--ink);line-height:1.2;margin-bottom:0.8rem}
.section-head h2 em{font-style:italic;color:var(--ink-2)}
.section-head p{color:var(--muted);font-size:1rem;max-width:560px;margin:0 auto}
section{padding:5rem 0}

/* NAV */
#navbar{position:fixed;top:0;width:100%;z-index:1000;background:rgba(255,255,255,0.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:all 0.3s}
#navbar.scrolled{box-shadow:var(--shadow)}
.nav-inner{max-width:1140px;margin:0 auto;padding:0 1.5rem;height:64px;display:flex;align-items:center;justify-content:space-between}
.logo{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;color:var(--ink);text-decoration:none}
.logo span{color:var(--accent)}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{color:var(--muted);text-decoration:none;font-size:0.875rem;font-weight:500;transition:color 0.2s}
.nav-links a:hover{color:var(--ink)}
.btn-nav{background:var(--accent);color:#fff;padding:0.55rem 1.25rem;border-radius:var(--radius);font-size:0.82rem;font-weight:600;text-decoration:none;transition:background 0.2s;white-space:nowrap}
.btn-nav:hover{background:var(--accent-dark)}
.menu-toggle{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--ink);line-height:1;padding:.25rem}

/* Nav dropdowns (desktop) */
.nav-has-dropdown{position:relative}
.nav-has-dropdown>a{display:flex;align-items:center;gap:.25rem}
.nav-dropdown-arrow{font-size:.55rem;color:var(--muted);transition:transform .2s;margin-left:.15rem}
.nav-has-dropdown:hover .nav-dropdown-arrow{transform:rotate(180deg)}
.nav-dropdown{position:absolute;top:calc(100% + 8px);left:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:.4rem 0;min-width:200px;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(6px);transition:all .18s;z-index:200;list-style:none}
.nav-has-dropdown:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown li a{display:block;padding:.55rem 1.1rem;font-size:.83rem;color:var(--muted);text-decoration:none;white-space:nowrap;transition:all .15s}
.nav-dropdown li a:hover{color:var(--ink);background:var(--bg-3)}

/* ── Mobile CTA hidden on desktop ── */
.nav-mobile-cta{display:none}

/* ── Mobile menu ── */
@media(max-width:768px){
  .menu-toggle{display:block}
  .btn-nav{display:none}

  .nav-links{
    display:none;
    flex-direction:column;
    gap:0;
    position:fixed;
    top:64px;left:0;right:0;
    background:#fff;
    border-top:1px solid var(--border);
    box-shadow:0 8px 24px rgba(0,0,0,.12);
    max-height:calc(100vh - 64px);
    overflow-y:auto;
    z-index:998;
    padding:0 0 1rem;
  }
  .nav-links.open{display:flex}

  /* top-level items */
  .nav-links>li>a{
    display:flex;align-items:center;justify-content:space-between;
    padding:.9rem 1.25rem;
    font-size:.95rem;font-weight:500;color:var(--ink);
    border-bottom:1px solid var(--bg-3);
    text-decoration:none;
  }
  .nav-links>li>a:active{background:var(--bg-2)}

  /* dropdown arrow */
  .nav-dropdown-arrow{font-size:.65rem;color:var(--muted);transition:transform .2s;flex-shrink:0}
  .nav-has-dropdown.mobile-open>.nav-dropdown-arrow{transform:rotate(180deg)}
  /* arrow is inside the <a>, make sure it rotates */
  .nav-has-dropdown.mobile-open>a .nav-dropdown-arrow{transform:rotate(180deg)}

  /* sub-menu */
  .nav-dropdown{
    position:static !important;
    opacity:1 !important;visibility:visible !important;transform:none !important;
    box-shadow:none !important;border:none !important;border-radius:0 !important;
    background:var(--bg-2);
    display:none;
    padding:0;
    min-width:unset;
    width:100%;
  }
  .nav-has-dropdown.mobile-open .nav-dropdown{display:block}

  .nav-dropdown li a{
    padding:.75rem 1.25rem .75rem 2rem;
    font-size:.875rem;color:var(--ink-2);
    border-bottom:1px solid var(--border);
    display:block;
    text-decoration:none;
    white-space:normal;
  }
  .nav-dropdown li:last-child a{border-bottom:none}
  .nav-dropdown li a:active{background:var(--bg-3);color:var(--accent)}

  /* CTA button at bottom of menu */
  .nav-mobile-cta{
    display:block;
    margin:.75rem 1.25rem;
    background:var(--accent);color:#fff !important;
    text-align:center;
    padding:.85rem;
    border-radius:var(--radius);
    font-size:.9rem;font-weight:600;
    text-decoration:none;
    border-bottom:none !important;
  }
  .nav-mobile-cta:active{background:var(--accent-dark)}
}

/* HERO */
.hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;padding:6rem 3rem 4rem 3rem;max-width:1140px;margin:0 auto}
.hero-badge{display:inline-flex;align-items:center;gap:0.4rem;font-size:0.8rem;font-weight:500;color:var(--muted);background:var(--bg-3);border:1px solid var(--border);padding:0.35rem 0.9rem;border-radius:999px;margin-bottom:1.5rem}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(2.5rem,4.5vw,4rem);font-weight:700;line-height:1.1;color:var(--ink);margin-bottom:1.25rem}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero-sub{font-size:1.05rem;color:var(--muted);margin-bottom:2rem;line-height:1.8;max-width:460px}
.hero-actions{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;margin-bottom:3rem}
.btn-primary{background:var(--accent);color:#fff;padding:0.85rem 2rem;border-radius:var(--radius);font-size:0.9rem;font-weight:600;text-decoration:none;transition:all 0.2s;display:inline-block}
.btn-primary:hover{background:var(--accent-dark);transform:translateY(-1px);box-shadow:0 8px 20px rgba(0,102,255,0.25)}
.btn-ghost{color:var(--accent);font-size:0.9rem;font-weight:500;text-decoration:none;transition:opacity 0.2s}
.btn-ghost:hover{opacity:0.7}
.hero-stats{display:flex;align-items:center;gap:1.5rem;padding-top:2rem;border-top:1px solid var(--border)}
.stat{text-align:center}
.stat-num{display:block;font-size:1.6rem;font-weight:700;color:var(--ink);line-height:1}
.stat-label{font-size:0.72rem;color:var(--muted);letter-spacing:0.04em;text-transform:uppercase;margin-top:0.2rem;display:block}
.stat-div{width:1px;height:2.5rem;background:var(--border)}

/* BROWSER MOCK */
.hero-visual{position:relative}
.browser-mock{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}
.browser-bar{background:var(--bg-3);padding:0.75rem 1rem;display:flex;align-items:center;gap:0.4rem;border-bottom:1px solid var(--border)}
.dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.dot.red{background:#ff5f57}.dot.yellow{background:#febc2e}.dot.green{background:#28c840}
.browser-url{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:0.2rem 0.8rem;font-size:0.72rem;color:var(--muted);margin-left:0.5rem}
.browser-body{padding:1rem}
.mock-nav{height:10px;background:var(--ink);border-radius:2px;margin-bottom:0.8rem;opacity:0.9}
.mock-hero{background:var(--bg-3);padding:1.2rem;border-radius:var(--radius);margin-bottom:0.8rem}
.mock-h1{height:12px;background:var(--ink);border-radius:3px;width:70%;margin-bottom:0.6rem;opacity:0.7}
.mock-h2{height:8px;background:var(--border-2);border-radius:3px;width:90%;margin-bottom:0.4rem}
.mock-h2:last-of-type{width:55%}
.mock-btns{display:flex;gap:0.5rem;margin-top:0.8rem}
.mock-btn{height:20px;width:80px;border-radius:4px}
.mock-btn.solid{background:var(--accent)}
.mock-btn.outline{border:1.5px solid var(--border-2)}
.mock-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:0.5rem}
.mock-card{background:var(--bg-3);border:1px solid var(--border);padding:0.6rem;border-radius:var(--radius)}
.mock-icon{width:18px;height:18px;background:var(--accent);border-radius:4px;opacity:0.6;margin-bottom:0.4rem}
.mock-lines div{height:6px;background:var(--border-2);border-radius:2px;margin-bottom:0.25rem}
.mock-lines div:last-child{width:65%}
.hero-tag-float{position:absolute;background:var(--bg);border:1px solid var(--border);border-radius:999px;padding:0.4rem 0.9rem;font-size:0.78rem;font-weight:600;color:var(--success);box-shadow:var(--shadow-md);white-space:nowrap}
.tag1{top:-0.5rem;right:1.5rem}
.tag2{bottom:1.5rem;left:-1rem}

/* ABOUT */
.about-strip{background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.about-text .section-tag{display:block;margin-bottom:0.8rem}
.about-text h2{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3vw,2.5rem);font-weight:600;line-height:1.2;margin-bottom:1.2rem;color:var(--ink)}
.about-text h2 em{font-style:italic;color:var(--accent)}
.about-text p{color:var(--muted);margin-bottom:1rem;line-height:1.8}
.about-skills{display:flex;flex-wrap:wrap;gap:0.5rem;margin-top:1.5rem}
.about-skills span{background:var(--bg);border:1px solid var(--border);color:var(--ink-2);font-size:0.78rem;font-weight:500;padding:0.3rem 0.8rem;border-radius:999px}
.about-numbers{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.about-num-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;text-align:center;transition:box-shadow 0.2s}
.about-num-card:hover{box-shadow:var(--shadow-md)}
.big-num{font-family:'Playfair Display',serif;font-size:2.5rem;font-weight:700;color:var(--ink);display:block;line-height:1}
.big-num .plus{color:var(--accent);font-size:1.5rem}
.num-label{font-size:0.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em;margin-top:0.4rem;display:block}

/* PROCESS */
.process{background:var(--bg)}
.steps{display:grid;grid-template-columns:repeat(5,1fr) repeat(4,auto);align-items:start;gap:0;margin-top:3rem}
.steps{display:flex;align-items:flex-start;gap:0;overflow-x:auto;padding-bottom:1rem}
.step{flex:1;min-width:140px;text-align:center;padding:0 0.75rem}
.step-num{width:48px;height:48px;border-radius:50%;background:var(--accent);color:#fff;font-size:1.1rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}
.step h3{font-size:0.95rem;font-weight:600;color:var(--ink);margin-bottom:0.5rem}
.step p{font-size:0.82rem;color:var(--muted);line-height:1.6}
.step-arrow{color:var(--border-2);font-size:1.5rem;margin-top:1.1rem;flex-shrink:0;padding:0 0.25rem}

/* PACKAGES */
.packages{background:var(--bg-2);border-top:1px solid var(--border)}
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:stretch}
.pkg-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;display:flex;flex-direction:column;position:relative;transition:box-shadow 0.2s,transform 0.2s}
.pkg-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.pkg-card.featured{border-color:var(--accent);border-width:2px}
.pkg-badge{display:inline-block;font-size:0.68rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:0.28rem 0.7rem;border-radius:999px;background:var(--bg-3);color:var(--muted);margin-bottom:1.2rem}
.pkg-badge.popular{background:var(--accent);color:#fff}
.pkg-name{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:600;color:var(--ink);margin-bottom:0.3rem}
.pkg-sub{font-size:0.82rem;color:var(--muted);margin-bottom:1.5rem}
.pkg-price{font-family:'Playfair Display',serif;font-size:3.2rem;font-weight:700;color:var(--ink);line-height:1;margin-bottom:0.3rem}
.pkg-price sup{font-size:1.2rem;vertical-align:super}
.pkg-mo{font-size:0.8rem;color:var(--muted);margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.pkg-features{list-style:none;flex:1;margin-bottom:2rem}
.pkg-features li{font-size:0.875rem;color:var(--ink-2);padding:0.45rem 0;border-bottom:1px solid var(--bg-3);display:flex;align-items:center;gap:0.5rem}
.pkg-features li::before{content:'✓';color:var(--success);font-weight:700;font-size:0.8rem;flex-shrink:0}
.pkg-btn{display:block;text-align:center;padding:0.85rem;border-radius:var(--radius);font-size:0.85rem;font-weight:600;text-decoration:none;border:1.5px solid var(--ink);color:var(--ink);transition:all 0.2s;margin-top:auto}
.pkg-btn:hover{background:var(--ink);color:#fff}
.pkg-btn.featured-btn{background:var(--accent);color:#fff;border-color:var(--accent)}
.pkg-btn.featured-btn:hover{background:var(--accent-dark)}

/* REVIEWS */
.reviews-section{background:var(--bg)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.review-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:box-shadow 0.2s,transform 0.2s;display:flex;flex-direction:column}
.review-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.review-stars{display:flex;align-items:center;gap:0.15rem;margin-bottom:0.75rem}
.star{font-size:0.9rem;line-height:1}
.star.full{color:#f59e0b}
.star.half{color:#f59e0b;opacity:0.7}
.star.empty{color:var(--border-2)}
.rating-num{font-size:0.82rem;font-weight:600;color:var(--ink-2);margin-left:0.3rem}
.review-text{font-size:0.875rem;color:var(--ink-2);line-height:1.7;flex:1;margin-bottom:1rem;font-style:italic}
.review-footer{display:flex;align-items:center;gap:0.75rem;margin-bottom:0.75rem}
.reviewer-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.85rem;flex-shrink:0}
.reviewer-name{font-size:0.85rem;font-weight:600;color:var(--ink)}
.reviewer-country{font-size:0.75rem;color:var(--muted)}
.review-meta{display:flex;gap:0.75rem;font-size:0.72rem;color:var(--muted);flex-wrap:wrap}
.reviews-more{text-align:center;margin-top:2.5rem}
.btn-ghost-dark{color:var(--ink);font-size:0.9rem;font-weight:500;text-decoration:none;border:1.5px solid var(--border-2);padding:0.75rem 2rem;border-radius:var(--radius);transition:all 0.2s;display:inline-block}
.btn-ghost-dark:hover{border-color:var(--ink);background:var(--ink);color:#fff}

/* CONTACT */
.contact-section{background:var(--bg-2);border-top:1px solid var(--border)}
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:5rem;align-items:start}
.contact-left .section-tag{display:block;margin-bottom:0.8rem}
.contact-left h2{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3vw,2.5rem);font-weight:600;line-height:1.2;margin-bottom:1rem;color:var(--ink)}
.contact-left h2 em{font-style:italic;color:var(--accent)}
.contact-left>p{color:var(--muted);line-height:1.8;margin-bottom:2rem}
.contact-info-items{display:flex;flex-direction:column;gap:1rem}
.contact-info-item{display:flex;align-items:flex-start;gap:0.9rem;font-size:0.875rem;color:var(--muted)}
.info-icon{font-size:1rem;margin-top:0.1rem;flex-shrink:0}
.contact-info-item strong{display:block;color:var(--ink);font-weight:600;font-size:0.8rem;margin-bottom:0.1rem}
.contact-info-item a{color:var(--accent);text-decoration:none}

/* FORMS */
.lead-form,.booking-form{display:flex;flex-direction:column;gap:1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{display:flex;flex-direction:column;gap:0.35rem}
label{font-size:0.78rem;font-weight:600;color:var(--ink-2);letter-spacing:0.02em}
input,select,textarea{border:1.5px solid var(--border);border-radius:var(--radius);padding:0.7rem 0.9rem;font-family:'Inter',sans-serif;font-size:0.9rem;color:var(--ink);background:var(--bg);transition:border-color 0.2s,box-shadow 0.2s;outline:none;width:100%}
input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,102,255,0.1)}
select{-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%236b7280' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 0.9rem center;padding-right:2.5rem}
textarea{resize:vertical;min-height:100px}
.btn-submit{background:var(--accent);color:#fff;border:none;padding:0.95rem;border-radius:var(--radius);font-family:'Inter',sans-serif;font-size:0.9rem;font-weight:600;cursor:pointer;transition:all 0.2s;width:100%}
.btn-submit:hover{background:var(--accent-dark);transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,102,255,0.25)}
.btn-submit.white{background:#fff;color:var(--accent);border:2px solid #fff}
.btn-submit.white:hover{background:var(--accent-light);box-shadow:none}
.form-note{font-size:0.75rem;color:var(--muted);text-align:center}
.form-error{background:#fef2f2;border:1px solid #fecaca;color:var(--error);padding:0.75rem;border-radius:var(--radius);font-size:0.85rem}
.form-success{text-align:center;padding:2.5rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg)}
.success-icon{font-size:3rem;margin-bottom:1rem}
.form-success h3{font-size:1.3rem;color:var(--ink);margin-bottom:0.5rem}
.form-success p{color:var(--muted)}

/* BOOKING */
.booking-section{background:var(--accent);padding:5rem 0}
.booking-section .section-head.light .section-tag{color:#fff;background:rgba(255,255,255,0.2)}
.booking-section .section-head h2{color:#fff}
.booking-section .section-head p{color:rgba(255,255,255,0.75)}
.booking-form-wrap{max-width:640px;margin:0 auto;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);border-radius:var(--radius-lg);padding:2.5rem}
.booking-form input,.booking-form select{background:rgba(255,255,255,0.15);border-color:rgba(255,255,255,0.3);color:#fff}
.booking-form input::placeholder{color:rgba(255,255,255,0.6)}
.booking-form label{color:rgba(255,255,255,0.85)}
.booking-form select option{background:var(--accent-dark);color:#fff}
.booking-form input:focus,.booking-form select:focus{border-color:#fff;box-shadow:0 0 0 3px rgba(255,255,255,0.2)}

/* FOOTER */
footer{background:var(--ink);color:rgba(255,255,255,0.7);padding:4rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:var(--footer-cols,2fr 1fr 1fr 1.5fr);gap:3rem;margin-bottom:3rem}
.footer-logo{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;color:#fff;margin-bottom:0.75rem}
.footer-logo span{color:var(--accent)}
.footer-desc{font-size:0.85rem;line-height:1.7;max-width:220px}
footer h4{font-size:0.78rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:#fff;margin-bottom:1rem}
footer ul{list-style:none;display:flex;flex-direction:column;gap:0.6rem}
footer ul li,footer ul a{font-size:0.85rem;color:rgba(255,255,255,0.55);text-decoration:none;transition:color 0.2s}
footer ul a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center}
.footer-bottom p{font-size:0.8rem;color:rgba(255,255,255,0.35)}
.footer-bottom a{color:rgba(255,255,255,0.4);text-decoration:none;transition:color .2s}
.footer-bottom a:hover{color:rgba(255,255,255,0.8)}
.footer-social{display:flex;gap:.6rem;margin-top:1.25rem}
.footer-social a{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.5);transition:all .2s;text-decoration:none;flex-shrink:0}
.footer-social a:hover{background:var(--accent);color:#fff}
.footer-social svg{width:15px;height:15px}

/* ADMIN */
.admin-wrap{display:block;min-height:100vh}
.admin-sidebar{background:var(--ink);color:#fff;padding:1.5rem 0;position:fixed;top:0;left:0;height:100vh;overflow-y:auto;z-index:100;width:240px;transition:width .2s}
.admin-wrap.nav-collapsed .admin-sidebar{width:64px}
.admin-main{margin-left:240px;transition:margin-left .2s}
.admin-wrap.nav-collapsed .admin-main{margin-left:64px}
.admin-logo{padding:0 1.5rem 1.5rem;font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:#fff;border-bottom:1px solid rgba(255,255,255,0.1);margin-bottom:1rem}
.admin-logo .logo-text{color:var(--bg)}
.admin-logo span{color:var(--accent)}
.admin-nav a{display:flex;align-items:center;gap:0.75rem;padding:0.75rem 1.5rem;color:rgba(255,255,255,0.6);text-decoration:none;font-size:0.875rem;font-weight:500;transition:all 0.15s}
.admin-nav a:hover,.admin-nav a.active{color:#fff;background:rgba(255,255,255,0.08)}
.admin-nav a .nav-icon{width:18px;text-align:center;flex-shrink:0}
.admin-main{background:var(--bg-2);padding:2rem;min-height:100vh}
/* sidebar collapsed */
.admin-wrap.nav-collapsed .admin-sidebar{padding:1.25rem 0}
.admin-wrap.nav-collapsed .admin-logo{padding:0 0 1.25rem;justify-content:center}
.admin-wrap.nav-collapsed .logo-text{display:none}
.admin-wrap.nav-collapsed .admin-nav a{justify-content:center;padding:.75rem 0;gap:0}
.admin-wrap.nav-collapsed .admin-nav a .nav-label{display:none}
.admin-wrap.nav-collapsed .admin-nav a .nav-icon{width:auto;font-size:1.1rem}
.sidebar-toggle{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.45);font-size:.75rem;padding:.25rem .4rem;border-radius:4px;line-height:1;transition:color .15s;flex-shrink:0}
.sidebar-toggle:hover{color:#fff}
.admin-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}
.admin-topbar h1{font-size:1.4rem;font-weight:700;color:var(--ink)}
.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}
.stat-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem}
.stat-card-num{font-size:2rem;font-weight:700;color:var(--ink);line-height:1}
.stat-card-label{font-size:0.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em;margin-top:0.3rem}
.stat-card-change{font-size:0.75rem;color:var(--success);margin-top:0.2rem}
.admin-table-wrap{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.admin-table-head{padding:1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.admin-table-head h2{font-size:1rem;font-weight:600;color:var(--ink)}
table{width:100%;border-collapse:collapse}
th{background:var(--bg-3);padding:0.75rem 1rem;text-align:left;font-size:0.72rem;font-weight:700;letter-spacing:0.07em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border)}
td{padding:0.85rem 1rem;font-size:0.875rem;color:var(--ink-2);border-bottom:1px solid var(--bg-3)}
tr:hover td{background:var(--bg-2)}
tr:last-child td{border-bottom:none}
.badge{display:inline-block;font-size:0.68rem;font-weight:600;padding:0.2rem 0.6rem;border-radius:999px;text-transform:capitalize}
.badge-new{background:#dbeafe;color:#1d4ed8}
.badge-contacted{background:#fef9c3;color:#854d0e}
.badge-demo_sent{background:#ede9fe;color:#6d28d9}
.badge-pending{background:#f0fdf4;color:#166534}
.badge-closed{background:#dcfce7;color:#166534}
.badge-lost{background:#fee2e2;color:#991b1b}
.badge-confirmed{background:#dcfce7;color:#166534}
.badge-cancelled{background:#fee2e2;color:#991b1b}
.badge-completed{background:#dbeafe;color:#1d4ed8}
.action-btn{background:none;border:none;cursor:pointer;font-size:0.8rem;color:var(--accent);font-family:'Inter',sans-serif;text-decoration:underline;padding:0}
.action-btn.danger{color:var(--error)}
.admin-form{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;max-width:700px}
.admin-form h2{font-size:1.1rem;font-weight:600;color:var(--ink);margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.admin-btn{background:var(--accent);color:#fff;border:none;padding:0.7rem 1.5rem;border-radius:var(--radius);font-family:'Inter',sans-serif;font-size:0.875rem;font-weight:600;cursor:pointer;transition:background 0.2s;text-decoration:none;display:inline-block}
.admin-btn:hover{background:var(--accent-dark)}
.admin-btn.secondary{background:var(--bg);color:var(--ink);border:1.5px solid var(--border)}
.admin-btn.secondary:hover{background:var(--bg-3)}
.admin-btn.danger{background:var(--error)}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-2)}
.login-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:400px}
.login-card h1{font-family:'Playfair Display',serif;font-size:1.5rem;margin-bottom:0.3rem;color:var(--ink)}
.login-card p{color:var(--muted);font-size:0.875rem;margin-bottom:1.5rem}
.alert{padding:0.75rem 1rem;border-radius:var(--radius);font-size:0.85rem;margin-bottom:1rem}
.alert-success{background:#dcfce7;color:var(--success);border:1px solid #bbf7d0}
.alert-error{background:#fee2e2;color:var(--error);border:1px solid #fecaca}
.alert-info{background:#dbeafe;color:#1d4ed8;border:1px solid #bfdbfe}

/* RESPONSIVE */
@media(max-width:1024px){
  .hero{grid-template-columns:1fr;gap:2rem;padding:7rem 1.5rem 3rem}
  .hero-visual{display:none}
  .about-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .admin-sidebar{display:none}
  .admin-main{margin-left:0!important}
}
@media(max-width:768px){
  .pkg-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .steps{flex-wrap:wrap;justify-content:center}
  .step-arrow{display:none}
  .admin-stats{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding-top:1.5rem}
  .hero-stats .stat{text-align:left;padding:.75rem 1rem;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius)}
  .hero-stats .stat-num{font-size:1.4rem}
  .stat-div{display:none}
  .footer-grid{grid-template-columns:1fr}
}

.text-primary{color:var(--accent)}
.bg-primary{background:var(--accent)}
.text-muted{color:var(--muted)}
.bg-muted{background:var(--muted)}
.text-success{color:var(--success)}
.bg-success{background:var(--success)}
.text-error{color:var(--error)}
.bg-error{background:var(--error)}
.rounded{border-radius:var(--radius)}
.shadow{box-shadow:var(--shadow)}
.text-white{color:#fff}
.bg-white{background:#fff}
