
* { box-sizing: border-box; }
:root{
  --bg:#f4f6ef; --surface:#fff; --text:#163124; --muted:#597365; --line:rgba(22,49,36,.12);
  --primary:#2f6f4f; --primary-dark:#24543c; --soft:#dcebc8; --shadow:0 18px 50px rgba(20,41,28,.10); --radius:24px;
}
html { scroll-behavior:smooth; }
body{ margin:0; font-family:"Inter",system-ui,sans-serif; color:var(--text); background:var(--bg); }
a{ color:inherit; text-decoration:none; } img{ max-width:100%; display:block; }
.container{ width:min(1180px, calc(100% - 32px)); margin:0 auto; }

.site-header{
  position:sticky; top:0; z-index:50; background:rgba(247,250,243,.9);
  backdrop-filter: blur(14px); border-bottom:1px solid rgba(255,255,255,.5);
}
.nav-wrap{
  min-height:78px; display:flex; align-items:center; justify-content:space-between; gap:18px;
  overflow:visible; position:relative;
}
.brand{ display:inline-flex; align-items:center; gap:10px; font-weight:800; font-size:1.2rem; }
.brand-badge{
  width:40px; height:40px; border-radius:14px; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--primary),#6aa06f); color:#fff; box-shadow:var(--shadow);
}
.nav{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; position:relative; z-index:60; }
.nav > a, .dropbtn{
  border:0; background:transparent; font:inherit; color:var(--text); padding:10px 12px; border-radius:12px; cursor:pointer;
}
.nav > a:hover, .dropbtn:hover{ background:rgba(47,111,79,.08); }
.nav-cta{ background:var(--primary); color:#fff !important; }
.dropdown{ position:relative; }
.dropdown-content{
  display:none; position:absolute; top:100%; left:0; min-width:230px;
  background:rgba(255,255,255,.98); backdrop-filter:blur(14px); padding:10px; border-radius:18px;
  border:1px solid var(--line); box-shadow:var(--shadow); z-index:999;
  opacity:0; transform:translateY(10px); transition:all .2s ease;
}
.dropdown-content a{ display:block; padding:10px 12px; border-radius:12px; }
.dropdown-content a:hover{ background:rgba(47,111,79,.08); }
.dropdown:hover .dropdown-content{ display:block; opacity:1; transform:translateY(0); }
.menu-toggle, .hamburger{ display:none; }

.hero{
  position:relative; min-height:88vh; display:flex; align-items:center; overflow:hidden;
}
.hero-bg{
  position:absolute; inset:0; background-image:url("assets/hero-bg.webp");
  background-size:cover; background-position:center; transform:scale(1.02);
}
.hero-overlay{
  position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(9,32,20,.75) 0%, rgba(20,48,31,.52) 34%, rgba(18,38,27,.18) 66%, rgba(255,255,255,.03) 100%);
}
.hero-grid{ position:relative; z-index:2; padding:84px 0 56px; display:grid; grid-template-columns:1.06fr .84fr; gap:28px; }
.glass{
  background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.16);
  box-shadow:var(--shadow); backdrop-filter:blur(12px); border-radius:28px;
}
.hero-copy{ color:#fff; padding:36px; align-self:center; }
.hero-panel{ color:#fff; padding:28px; align-self:end; }
.eyebrow,.section-kicker{
  margin:0 0 12px; text-transform:uppercase; letter-spacing:.12em; font-size:.8rem; font-weight:700;
}
.hero h1{ margin:0; font-size:clamp(2.5rem,6vw,4.8rem); line-height:1.03; max-width:12ch; }
.hero-text,.lead{ font-size:1.05rem; line-height:1.7; color:rgba(255,255,255,.92); }
.hero-actions,.auth-actions{ display:flex; gap:12px; flex-wrap:wrap; margin-top:24px; }

.btn{
  display:inline-flex; align-items:center; justify-content:center; min-height:48px; padding:0 18px;
  border-radius:14px; border:1px solid transparent; cursor:pointer; font-weight:700;
}
.btn.primary{ background:var(--primary); color:#fff; }
.btn.primary:hover{ background:var(--primary-dark); }
.btn.secondary{ background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.28); color:#fff; }
.btn.dark{ background:#e7f0df; color:var(--text); }
.btn.ghost{ background:#eef3ea; color:var(--text); }
.btn.google-btn{ background:#fff; color:#1f1f1f; border:1px solid rgba(22,49,36,.12); }
.btn.warn{ background:#fff2d5; color:#7b5600; }
.btn.danger{ background:#ffe3e3; color:#8f1d1d; }
.btn.sm{ min-height:40px; padding:0 14px; border-radius:12px; font-size:.92rem; }

.search-card{
  margin-top:26px; display:grid; grid-template-columns:1fr auto; gap:10px;
  background:rgba(255,255,255,.14); padding:12px; border-radius:18px;
}
.search-card input, .form-card input, .form-card textarea, .form-card select,
.auth-form input, .auth-form textarea, .auth-form select{
  width:100%; border:1px solid rgba(22,49,36,.08); background:#f8faf5; border-radius:14px; padding:14px 16px; font:inherit; outline:none;
}
.search-card input{ background:#fff; color:var(--text); border-color:transparent; }
.search-card button{ border:0; border-radius:14px; background:#dcedd2; color:var(--text); font:inherit; font-weight:700; cursor:pointer; padding:0 18px; }
.search-result,.form-message,.tiny-muted{ color:var(--muted); line-height:1.7; }
.hero .search-result{ color:#e7f9ea; min-height:24px; margin:12px 2px 0; }

.quick-grid,.card-grid,.admin-grid,.auth-shell,.stats-grid,.category-grid{ display:grid; gap:18px; }
.quick-grid{ grid-template-columns:repeat(2,minmax(0,1fr)); }
.quick-card{
  min-height:132px; padding:18px; border-radius:22px; background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.12); display:flex; flex-direction:column; gap:10px;
}
.quick-card span{ font-size:1.5rem; }
.quick-card small{ color:rgba(255,255,255,.84); line-height:1.55; }

.section{ padding:88px 0; }
.section.alt{ background:linear-gradient(180deg, rgba(220,235,200,.28), rgba(255,255,255,.8)); }
.section-head{ margin-bottom:28px; }
.section-head.center{ text-align:center; max-width:760px; margin-inline:auto; }
.section-head h2{ margin:0; font-size:clamp(1.8rem,4vw,2.9rem); }
.section-head p:not(.section-kicker){ color:var(--muted); line-height:1.7; }

.card-grid.three{ grid-template-columns:repeat(3,minmax(0,1fr)); }
.card-grid.four{ grid-template-columns:repeat(4,minmax(0,1fr)); }

.info-card,.guide-card,.mini-card,.qa-card,.form-card,.note-card,.auth-card,.status-card,.setup-card,.admin-card,.category-hero,.feed-item,.role-card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow);
}
.info-card,.guide-card,.mini-card,.qa-card,.note-card,.auth-card,.status-card,.setup-card,.admin-card,.feed-item,.role-card{ padding:24px; }
.info-card p,.guide-card p,.mini-card p,.qa-card p,.note-card p,.feed-item p,.status-card p,.setup-card p,.role-card p{ color:var(--muted); line-height:1.7; margin-bottom:0; }

.tag{
  display:inline-flex; padding:7px 12px; border-radius:999px; background:var(--soft); color:var(--primary-dark);
  font-size:.8rem; font-weight:700; margin-bottom:10px;
}
.tag.pending{ background:#fff2d5; color:#7b5600; }
.tag.approved{ background:#dff2dd; color:#24543c; }
.tag.rejected{ background:#ffe3e3; color:#8f1d1d; }

.two-col{ display:grid; grid-template-columns:1.15fr .85fr; gap:24px; align-items:start; }
.form-card,.auth-card,.status-card,.setup-card,.admin-card{ padding:26px; }
.form-card label,.auth-form label{ display:block; font-weight:600; margin-bottom:14px; }
.form-card input,.form-card textarea,.form-card select,.auth-form input,.auth-form textarea,.auth-form select{ margin-top:8px; }

.stack,.notes-list,.feed-list{ display:grid; gap:18px; }
.list-header{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.text-btn{ border:0; background:transparent; color:var(--primary); font-weight:700; cursor:pointer; }
.feed-item h4{ margin:0 0 8px; font-size:1rem; }
.feed-meta{ margin-top:8px; font-size:.84rem; color:#6b8778; }

.auth-shell{ grid-template-columns:1fr .95fr; }
.user-status{ padding:16px; border-radius:18px; background:#f7fbf3; border:1px solid var(--line); }
.status-points{ display:grid; gap:16px; margin-top:16px; }

.hidden{ display:none !important; }
.panel-shell{ background:linear-gradient(180deg, rgba(47,111,79,.06), rgba(255,255,255,.96)); border-radius:28px; }
.admin-grid{ grid-template-columns:1.1fr .9fr; }
.admin-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin:18px 0; }
.stat-box{ padding:18px; border-radius:20px; background:#f7fbf3; border:1px solid var(--line); text-align:center; }
.stat-box strong{ display:block; font-size:1.8rem; margin-bottom:4px; }
code{ padding:2px 6px; border-radius:8px; background:#eef3ea; }

.guide-thumb{
  width:100%; aspect-ratio:16/9; object-fit:cover; border-radius:18px; margin-bottom:14px; border:1px solid var(--line); background:#eef3ea;
}
.category-grid{ grid-template-columns:repeat(3,minmax(0,1fr)); }
.category-chip{
  display:inline-flex; align-items:center; justify-content:center; min-height:46px; padding:0 16px; border-radius:999px; background:#eef3ea; font-weight:700;
}
.category-hero{ padding:28px; }
.empty-state{ padding:28px; border-radius:24px; border:1px dashed var(--line); background:#f8fbf5; color:var(--muted); }
.actions-row{ display:flex; gap:10px; flex-wrap:wrap; margin-top:14px; }
.site-footer{ padding:28px 0 40px; border-top:1px solid var(--line); background:#eef4e6; }
.footer-wrap{ display:flex; justify-content:space-between; gap:20px; align-items:center; }
.footer-wrap p{ color:var(--muted); margin-bottom:0; }
.footer-links{ display:flex; gap:16px; flex-wrap:wrap; }

@media (max-width:1080px){
  .hero-grid,.two-col,.card-grid.three,.card-grid.four,.admin-grid,.auth-shell,.category-grid{ grid-template-columns:1fr; }
  .admin-stats{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:860px){
  .hamburger{
    display:inline-flex; width:46px; height:46px; align-items:center; justify-content:center;
    border-radius:14px; cursor:pointer; background:#fff; border:1px solid var(--line);
  }
  .nav{
    display:none; position:absolute; top:78px; left:16px; right:16px; background:rgba(255,255,255,.98);
    border:1px solid var(--line); border-radius:22px; padding:14px; box-shadow:var(--shadow);
    flex-direction:column; align-items:stretch;
  }
  .menu-toggle:checked + .hamburger + .nav{ display:flex; }
  .dropdown-content{ position:static; display:block; box-shadow:none; background:transparent; border:0; padding:0 0 0 10px; opacity:1; transform:none; }
  .dropbtn{ text-align:left; padding-left:0; }
  .quick-grid,.admin-stats,.category-grid{ grid-template-columns:1fr; }
  .search-card{ grid-template-columns:1fr; }
  .footer-wrap{ flex-direction:column; align-items:flex-start; }
}

.center-text{text-align:center;}
.tag-list{display:flex; flex-wrap:wrap; gap:8px; margin-top:14px;}
.chip{display:inline-flex; padding:7px 12px; border-radius:999px; background:#eef3ea; color:#2f6f4f; font-size:.82rem; font-weight:700;}
.inline-note{margin-top:12px; padding:12px 14px; border-radius:14px; background:#f7fbf3;}
.danger-note{background:#ffe9e9; color:#8f1d1d;}
.search-advanced{grid-template-columns:2fr 1.1fr 1fr auto;}
.moderation-toolbar{display:grid; grid-template-columns:.9fr 1fr 1fr; gap:12px; margin-bottom:18px;}
.moderation-toolbar select,.moderation-toolbar textarea{width:100%; border:1px solid rgba(22,49,36,.08); background:#f8faf5; border-radius:14px; padding:14px 16px; font:inherit;}
.detail-card{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden;}
.detail-hero{width:100%; max-height:480px; object-fit:cover; display:block; background:#eef3ea;}
.detail-body{padding:28px;}
.detail-body h1{margin:10px 0 0; font-size:clamp(2rem,4vw,3rem);}
.detail-summary{font-size:1.05rem; line-height:1.8; color:var(--muted);}
.detail-block{margin-top:24px;}
.detail-block h3{margin-bottom:10px;}
.detail-content{line-height:1.9; color:var(--text);}
.gallery-grid{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px;}
.gallery-grid img{width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:18px; border:1px solid var(--line); background:#eef3ea;}
.link-list{display:grid; gap:10px;}
.link-list a{display:block; padding:12px 14px; border-radius:14px; background:#f7fbf3; border:1px solid var(--line); overflow-wrap:anywhere;}
@media (max-width:1080px){ .search-advanced,.moderation-toolbar,.gallery-grid{grid-template-columns:1fr;} }

.drop-link{display:inline-flex; align-items:center; text-decoration:none}
.nav a.active,.dropdown.active>.dropbtn{color:#0f766e; font-weight:700}
.nav-auth{display:flex; align-items:center; gap:10px; margin-left:14px}
.user-badge{font-size:.82rem; color:#0f172a; background:#ecfeff; border:1px solid #a5f3fc; padding:8px 12px; border-radius:999px; max-width:220px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.nav-auth-btn.is-logged-in{background:#0f172a}
.header-auth-panel{position:fixed; inset:0; background:rgba(15,23,42,.45); display:none; align-items:flex-start; justify-content:flex-end; padding:88px 20px 20px; z-index:90}
.header-auth-panel.open{display:flex}
.header-auth-card{width:min(420px,100%); background:#fff; border-radius:22px; box-shadow:0 25px 80px rgba(15,23,42,.2); padding:22px}
.header-auth-head{display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:10px}
.icon-close{border:none; background:#f1f5f9; width:36px; height:36px; border-radius:999px; font-size:1.4rem; cursor:pointer}
.auth-form.compact label{margin-bottom:12px}
.auth-form.compact .auth-actions{margin-top:8px}
.hidden{display:none !important}
@media (max-width: 980px){
  .nav-wrap{flex-wrap:wrap}
  .nav-auth{width:100%; justify-content:flex-end; margin:10px 0 0}
  .user-badge{max-width:100%}
}
