/* Basic reset & variables */
:root{
  --bg-overlay: rgba(7,20,30,0.65);
  --glass-border: rgba(255,255,255,0.25);
  --text: #ced3d6;
  --muted: rgba(196, 199, 201, 0.7);
  --accent: #2eb872;
  --accent-2: #2bb5ff;
  --card-shadow: 0 8px 30px rgba(2,6,23,0.45);
  --container-width: 1100px;
}

[data-theme="dark"]{
  --bg-overlay: rgba(2,6,12,0.75);
  --glass-bg: rgba(5,10,18,0.42);
  --glass-border: rgba(255,255,255,0.04);
  --text: #e6f7ff;
  --muted: rgba(230,247,255,0.65);
  --accent: #5ce0a6;
  --accent-2: #66c7ff;
  --card-shadow: 0 10px 40px rgba(0,0,0,0.6);
}

a{
    color: #ced3d6;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  background-image: url('../images/lawn-bg.jpg');
  background-size:cover;
  background-position:center;
  background-attachment:fixed;
  position:relative;
  min-height:100vh;
}

/* dimmed overlay over background */
body::before{
  content:"";
  position:fixed;
  inset:0;
  background: linear-gradient(to bottom right, var(--bg-overlay), rgba(0,0,0,0.65));
  pointer-events: none;
  z-index:0;
  
}

.container{max-width:var(--container-width);margin:0 auto;padding:1rem;position:relative;z-index:2}

/* Force hero + services to share the available viewport so page can fit in 1 screen */
main{display:flex;flex-direction:column;min-height:calc(100vh - 96px);justify-content:space-between;gap:0.4rem;transition:padding-bottom .18s ease, min-height .18s ease}
.site-footer{transition:margin-bottom .18s ease}
main > .hero{flex:1 1 60%;display:flex;align-items:center}
main > .services{flex:0 0 auto}
main{padding: 8px !important;}

/* reduce footer footprint to help fit above the fold */
.site-footer{padding:0.6rem 0;text-align:center;color:var(--muted)}

.site-header{position:sticky;top:0;backdrop-filter: blur(6px);z-index:40;padding:0.35rem 0} 
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:nowrap}
.brand{display:flex;gap:0.6rem;align-items:center;flex:1 1 auto;min-width:0}
.brand > div{min-width:0}
.logo{width:44px;height:44px;border-radius:8px;object-fit:cover;box-shadow:var(--card-shadow);border:1px solid rgba(255,255,255,0.06)}
.brand-name{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brand-sub{font-size:0.78rem;color:var(--muted);white-space:nowrap;opacity:0.85}
.nav{display:flex;gap:0.5rem;align-items:center;flex:0 0 auto;white-space:nowrap}
.nav-link{color:var(--muted);text-decoration:none;padding:0.25rem 0.45rem;font-size:0.95rem}
/* Buttons */
.btn{border:0;padding:0.6rem 0.9rem;border-radius:10px;cursor:pointer;font-weight:600}
.btn-ghost{background:transparent;color:var(--muted);border:1px solid rgba(255,255,255,0.06)}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#042a1f;box-shadow:0 6px 20px rgba(6,30,18,0.15)}
.btn-accent{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.06);color:var(--text)}

/* Hero */
.hero{display:flex;align-items:center;min-height:auto;padding:1.2rem 0}  
.hero-inner{max-width:820px;padding:0.9rem;border-radius:12px;background:var(--glass-bg);backdrop-filter:blur(10px) saturate(120%);border:1px solid var(--glass-border);box-shadow:var(--card-shadow);max-height:calc(100vh - 200px);overflow:hidden} 
.hero h1{margin:0 0 0.12rem;font-size:1.95rem}  
.lead{margin:0 0 0.6rem;color:var(--muted)}
.hero-ctas{display:flex;gap:0.6rem;margin-bottom:0.5rem} 
.email-line{color:var(--muted);font-size:0.9rem}

/* Services */
.services{padding:0.8rem 0}  
.services h2{margin-top:0}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:0.5rem;margin-top:0.4rem}

/* Desktop: force single-row of service cards (then responsive below breakpoint) */
@media (min-width:1000px){
  .cards{grid-template-columns:repeat(4,1fr);align-items:stretch}
  .card{min-height:120px}
} 
.card{padding:0.9rem;border-radius:12px;border:1px solid var(--glass-border);background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));min-height:120px;display:flex;flex-direction:column;gap:0.45rem} 
.card h3{margin:0}
.card p{margin:0;color:var(--muted);font-size:0.95rem}
.icon{font-size:1.6rem}

/* How */
.how{padding:2.8rem 0}
.how ol{padding-left:1.2rem;color:var(--muted)}

/* Footer */
.site-footer{padding:1rem 0;text-align:center;color:var(--muted)}

/* Glass common */
.glass{background:var(--glass-bg);border:1px solid var(--glass-border);backdrop-filter:blur(8px) saturate(140%)}

/* Header controls (desktop) + mobile menu */
#themeBtn{width:40px;height:40px;border-radius:999px;border:1px solid rgba(255,255,255,0.08);background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));cursor:pointer;font-size:16px;display:inline-flex;align-items:center;justify-content:center;transition:transform .12s ease, box-shadow .12s ease, background-color .12s ease, border-color .12s ease}
#themeBtn:hover{transform:translateY(-1px)}
#themeBtn:focus{outline: none; box-shadow: 0 6px 18px rgba(2,6,23,0.18);}
/* visual state when dark mode is active */
#themeBtn[aria-pressed="true"]{background:linear-gradient(180deg,#0f1720,#07101a);border-color:rgba(255,255,255,0.12);color:#fff;box-shadow:0 8px 30px rgba(2,6,23,0.55), inset 0 -2px 6px rgba(255,255,255,0.02)}
#themeBtn[aria-pressed="true"]:hover{box-shadow:0 10px 34px rgba(2,6,23,0.6)}
#themeBtn .theme-icon{display:inline-block;transition:transform .36s cubic-bezier(.2,.8,.2,1)}
#themeBtn[aria-pressed="true"] .theme-icon{transform:rotate(18deg) scale(1.06)}
#themeBtn[aria-pressed="false"] .theme-icon{transform:rotate(0) scale(1)}
/* visible label next to toggle */
.theme-text{margin-left:8px;font-size:0.95rem;color:var(--muted);vertical-align:middle;display:inline-block;transition:color .12s ease,transform .12s ease,opacity .12s ease}
#themeBtn[aria-pressed="true"] + .theme-text{color:var(--text);transform:translateY(-2px);animation:labelPop .18s ease}
#themeBtn[aria-pressed="false"] + .theme-text{color:var(--muted);transform:translateY(0);animation:labelPop .18s ease}
@keyframes labelPop{0%{transform:translateY(0) scale(.98);opacity:.9}50%{transform:translateY(-4px) scale(1.03);opacity:1}100%{transform:translateY(0) scale(1);opacity:1}}
/* slightly different appearance in light mode */
#themeBtn[aria-pressed="false"]{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));color:var(--text)}
.admin-link{display:inline-flex;align-items:center;gap:6px;padding:6px 8px;border-radius:10px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);color:var(--muted);font-size:12px;text-decoration:none;box-shadow:var(--card-shadow);opacity:0.95}
.admin-link:hover{opacity:1;background:rgba(255,255,255,0.06)}
[data-theme="dark"] .admin-link{background:rgba(255,255,255,0.02);border-color:rgba(255,255,255,0.04);color:var(--muted)}

/* hamburger for mobile */
.menu-toggle{display:none;border:0;background:transparent;color:var(--muted);font-size:20px;padding:6px 8px;border-radius:8px;cursor:pointer}

/* off-canvas mobile menu */
.mobile-menu{position:fixed;inset:0;display:none;align-items:flex-start;justify-content:flex-end;z-index:220}
.mobile-menu.open{display:flex}
.mobile-menu-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.45)}
.mobile-panel{position:relative;width:280px;max-width:86%;height:100%;padding:14px;border-radius:0 0 0 0;z-index:10;box-shadow:var(--card-shadow);border-left:1px solid rgba(255,255,255,0.03)}
.mobile-panel .mobile-close{position:absolute;right:12px;top:12px;border:0;background:transparent;font-size:18px}
.mobile-panel .nav-link{display:block;padding:8px 0;color:var(--muted)}
.mobile-panel .btn{width:100%}

/* hide desktop floating controls on small screens */
@media (max-width:820px){
  .theme-toggle{display:none}
  .menu-toggle{display:inline-flex}
}

/* hamburger for mobile */
.menu-toggle{display:none;border:0;background:transparent;color:var(--muted);font-size:20px;padding:6px 8px;border-radius:8px;cursor:pointer}

/* off-canvas mobile menu */
.mobile-menu{position:fixed;inset:0;display:none;align-items:flex-start;justify-content:flex-end;z-index:220}
.mobile-menu.open{display:flex}
.mobile-menu-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.45)}
.mobile-panel{position:relative;width:280px;max-width:86%;height:100%;padding:14px;border-radius:0 0 0 0;z-index:10;box-shadow:var(--card-shadow);border-left:1px solid rgba(255,255,255,0.03)}
.mobile-panel .mobile-close{position:absolute;right:12px;top:12px;border:0;background:transparent;font-size:18px}
.mobile-panel .nav-link{display:block;padding:8px 0;color:var(--muted)}
.mobile-panel .btn{width:100%}

/* hide desktop floating controls on small screens */
@media (max-width:820px){
  .theme-toggle{display:none}
  .menu-toggle{display:inline-flex}
}

/* Modal */
/* increased z-index so modals always appear above fixed UI (mini player, etc.) */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:2rem;z-index:1200}
.modal.open{display:flex}
.modal-overlay{position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,0,0,0.45), rgba(0,0,0,0.6));backdrop-filter:blur(4px);}
.modal-panel{position:relative;max-width:760px;width:100%;padding:1.25rem 1.5rem;border-radius:12px;z-index:1210; background-color: #363636;}
.modal-close{position:absolute;right:12px;top:12px;border:0;background:transparent;font-size:1.1rem;cursor:pointer}

/* Share modal specifics */
.share-actions .btn{min-width:120px}
#shareQr img{box-shadow:0 8px 30px rgba(2,6,23,0.2);max-width:100%}
#shareNotice{min-height:20px}
.form-row{display:flex;gap:0.75rem}
.form-row label{flex:1;display:flex;flex-direction:column;font-size:0.9rem}
.full{display:block;margin-top:0.75rem}
input,textarea{margin-top:0.35rem;padding:0.5rem 0.6rem;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:transparent;color:var(--text)}
.form-actions{display:flex;gap:0.5rem;align-items:center;margin-top:0.75rem}
.muted{color:var(--muted)}

/* Responsive */
@media (max-width:820px){
  .hero h1{font-size:1.8rem}
  .hero-inner{padding:1rem}
  .form-row{flex-direction:column}
  /* keep header on one line; hide desktop nav and show mobile hamburger */
  .header-inner{align-items:center}
  .nav{display:none}
  .menu-toggle{display:inline-flex}
}

/* height-aware adjustments to avoid unnecessary page scroll */
@media (max-height:720px){
  .hero{min-height:56vh;padding:0.8rem 0}
  .hero-inner{padding:0.7rem}
  .hero h1{font-size:1.5rem}
  .services{padding:0.6rem 0}
}

/* Mini audio player */
:root{--mini-player-height:96px}
.mini-player{position:fixed;left:18px;bottom:18px;z-index:260;display:flex;gap:10px;align-items:center;padding:8px;border-radius:999px;background:var(--glass-bg);border:1px solid var(--glass-border);box-shadow:var(--card-shadow);backdrop-filter:blur(8px);min-width:260px;max-width:420px}
.mini-player-cover{width:56px;height:56px;border-radius:8px;object-fit:cover;border:1px solid rgba(255,255,255,0.04)}
.mini-player-info{display:flex;flex-direction:column;gap:6px;min-width:160px}
.mini-player-title{font-weight:700;color:var(--text);font-size:0.95rem}
.mini-player-artist{font-size:0.82rem;color:var(--muted)}
.mini-player-controls{display:flex;align-items:center;gap:10px}
.mini-play{width:40px;height:40px;border-radius:999px;border:0;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#042a1f;font-weight:800;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 6px 20px rgba(6,30,18,0.12)}
.mini-play[aria-pressed="true"]{background:#ffdb6d}
.mini-progress{flex:1;height:6px;border-radius:6px;background:rgba(255,255,255,0.03);overflow:hidden;cursor:pointer;border:1px solid rgba(255,255,255,0.02)}
.mini-progress-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .12s linear}
.mini-times{font-size:0.78rem;color:var(--muted);min-width:64px;text-align:right}
.mini-player-close{position:relative;left:-6px;top:0;border:0;background:transparent;color:var(--muted);font-size:14px;cursor:pointer;padding:6px;border-radius:6px}
.open-mini-player{position:fixed;left:18px;bottom:18px;z-index:250;width:44px;height:44px;border-radius:999px;border:1px solid rgba(255,255,255,0.06);background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));display:none;align-items:center;justify-content:center;box-shadow:var(--card-shadow);cursor:pointer}
.open-mini-player.show{display:inline-flex}
@media (max-width:720px){ .mini-player{left:12px;right:12px;bottom:12px;min-width:unset;max-width:calc(100% - 24px)} .mini-player-info{min-width:120px} }

/* when mini player is visible, push main content up so it isn't covered */
body.has-mini-player main{padding-bottom:calc(var(--mini-player-height) + 18px + env(safe-area-inset-bottom));}
@media (max-width:720px){ body.has-mini-player main{padding-bottom:calc(var(--mini-player-height) + 24px + env(safe-area-inset-bottom));} }
