:root {
  --green: #087a2b;
  --green-2: #0c5f27;
  --green-dark: #11371e;
  --gold: #b08a3c;
  --cream: #fbf8f0;
  --text: #18221b;
  --muted: #66756d;
  --surface: #ffffff;
  --bg: #f7f6f1;
  --line: #e3ded0;
  --shadow: 0 20px 55px rgba(17, 55, 30, 0.10);
  --shadow-soft: 0 12px 30px rgba(17, 55, 30, 0.07);
  --radius: 24px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin:0; font-family: Inter, Arial, Helvetica, sans-serif; color:var(--text); background:var(--bg); line-height:1.65; }
a { color:var(--green-2); text-decoration:none; transition:.2s ease; }
a:hover { color:var(--gold); }
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(255,255,255,.88); backdrop-filter:blur(16px); border-bottom:1px solid rgba(17,55,30,.08); }
.nav-wrap { display:flex; align-items:center; justify-content:space-between; gap:18px; padding:13px 0; }
.brand { display:flex; align-items:center; gap:13px; color:inherit; min-width:260px; }
.brand img { width:58px; height:58px; object-fit:contain; filter:drop-shadow(0 8px 16px rgba(0,0,0,.08)); }
.brand strong { display:block; font-size:1rem; letter-spacing:-.02em; line-height:1.2; }
.brand span { display:block; color:var(--muted); font-size:.82rem; }
.site-nav { display:flex; align-items:center; gap:8px; }
.site-nav a { padding:10px 12px; border-radius:999px; font-weight:700; color:var(--green-dark); }
.site-nav a:hover { background:#eef6ef; color:var(--green-2); text-decoration:none; }
.nav-toggle { display:none; border:1px solid var(--line); background:#fff; border-radius:14px; padding:10px 13px; }
.button, button, input[type=submit] { border:0; background:var(--green); color:#fff; padding:12px 18px; border-radius:999px; cursor:pointer; font-weight:800; box-shadow:0 10px 20px rgba(8,122,43,.16); }
.button:hover, button:hover, input[type=submit]:hover { background:var(--green-2); color:#fff; text-decoration:none; transform:translateY(-1px); }
.button-outline { background:#fff; color:var(--green-2); border:1px solid rgba(8,122,43,.28); box-shadow:none; }
.button-outline:hover { background:#eef6ef; color:var(--green-2); }
.hero { padding:84px 0 64px; background:radial-gradient(circle at 10% 0%, rgba(8,122,43,.16), transparent 34%), radial-gradient(circle at 90% 20%, rgba(176,138,60,.16), transparent 28%), linear-gradient(135deg, #fff, var(--cream)); overflow:hidden; }
.hero-bg { position:relative; min-height:720px; display:flex; align-items:center; background-image:linear-gradient(90deg, rgba(8,32,17,.88), rgba(8,32,17,.58), rgba(8,32,17,.18)), var(--hero-bg); background-size:cover; background-position:center; color:#fff; }
.hero-bg .kicker { background:rgba(255,255,255,.16); color:#fff; border:1px solid rgba(255,255,255,.25); }
.hero-bg p.lead { color:rgba(255,255,255,.88); }
.hero-bg .stat { background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.18); backdrop-filter:blur(10px); }
.hero-bg .stat strong { color:#fff; }
.hero-bg .stat span { color:rgba(255,255,255,.82); }
.hero-bg .button-outline { background:rgba(255,255,255,.12); color:#fff; border-color:rgba(255,255,255,.35); }
.hero-bg .hero-card { background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.18); backdrop-filter:blur(8px); }
.hero-grid { display:grid; grid-template-columns:1.06fr .94fr; gap:42px; align-items:center; }
.kicker, .badge { display:inline-flex; align-items:center; gap:6px; padding:7px 12px; border-radius:999px; background:#edf6ef; color:var(--green-2); font-weight:800; font-size:.78rem; letter-spacing:.02em; margin-bottom:13px; }
h1,h2,h3,h4 { line-height:1.12; margin:0 0 14px; letter-spacing:-.03em; }
h1 { font-size:clamp(2.45rem, 5vw, 5rem); }
h2 { font-size:clamp(1.75rem, 3vw, 3rem); }
h3 { font-size:1.28rem; }
p.lead { font-size:1.13rem; color:var(--muted); max-width:700px; }
.hero-card, .card, .panel { background:var(--surface); border-radius:var(--radius); box-shadow:var(--shadow-soft); overflow:hidden; border:1px solid rgba(17,55,30,.08); }
.hero-card { padding:10px; transform:rotate(1deg); box-shadow:var(--shadow); }
.hero-card img { width:100%; height:460px; object-fit:cover; border-radius:18px; }
.section { padding:70px 0; }
.grid-3 { display:grid; grid-template-columns:repeat(3, 1fr); gap:24px; }
.grid-2 { display:grid; grid-template-columns:repeat(2, 1fr); gap:26px; }
.list-grid { display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:10px 18px; }
.feature-card, .panel { padding:28px; }
.feature-card p, .muted { color:var(--muted); }
.stats { display:grid; grid-template-columns:repeat(3, 1fr); gap:16px; margin-top:28px; }
.stat { background:rgba(255,255,255,.78); border:1px solid rgba(17,55,30,.08); border-radius:20px; padding:18px; box-shadow:var(--shadow-soft); }
.stat strong { display:block; font-size:1.75rem; color:var(--green-2); }
.projects-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:24px; }
.project-card { transition:.25s ease; }
.project-card:hover { transform:translateY(-5px); box-shadow:var(--shadow); }
.project-card img { width:100%; aspect-ratio:4/3; object-fit:cover; background:#e9e3d5; }
.project-content { padding:22px; }
.page-hero { padding:64px 0 30px; background:linear-gradient(180deg, #fff, var(--bg)); border-bottom:1px solid rgba(17,55,30,.06); }
.form-grid { display:grid; grid-template-columns:repeat(2, 1fr); gap:16px; }
label { display:block; font-weight:800; margin-bottom:8px; color:var(--green-dark); }
input[type=text], input[type=password], input[type=email], textarea, select { width:100%; padding:13px 14px; border-radius:14px; border:1px solid #d6d0c0; background:#fff; font:inherit; }
input:focus, textarea:focus { outline:3px solid rgba(8,122,43,.13); border-color:var(--green); }
textarea { min-height:140px; resize:vertical; }
input[type=file] { width:100%; padding:8px 0; }
.table-wrap { overflow:auto; }
table { width:100%; border-collapse:collapse; }
th,td { text-align:left; padding:14px 12px; border-bottom:1px solid #eee9dc; vertical-align:top; }
th { background:#fbfaf5; color:var(--green-dark); }
.actions { display:flex; gap:8px; flex-wrap:wrap; }
.flash { margin-top:16px; padding:14px 16px; border-radius:14px; font-weight:800; }
.flash-success { background:#e7f5ea; color:#0b6b27; }
.flash-error { background:#fde8e8; color:#a32828; }
.site-footer { margin-top:50px; background:#112016; color:#dfe9e1; padding:46px 0 18px; }
.site-footer a { color:#fff; }
.footer-grid { display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:24px; }
.footer-bottom { padding-top:22px; color:#b4c3b7; border-top:1px solid rgba(255,255,255,.1); margin-top:20px; }
.admin-shell { display:grid; grid-template-columns:270px 1fr; min-height:100vh; }
.admin-sidebar { background:linear-gradient(180deg, #102015, #0b3017); color:#fff; padding:28px 18px; }
.admin-sidebar a { color:#e7f5ea; display:block; padding:11px 13px; border-radius:12px; }
.admin-sidebar a:hover,.admin-sidebar a.active { background:rgba(255,255,255,.10); text-decoration:none; }
.admin-main { padding:28px; }
.admin-card { background:#fff; border-radius:22px; padding:25px; box-shadow:var(--shadow-soft); margin-bottom:22px; border:1px solid rgba(17,55,30,.08); }
.login-wrap { min-height:100vh; display:grid; place-items:center; padding:22px; background:linear-gradient(135deg, #fff, var(--cream)); }
.login-card { width:min(460px, 100%); background:#fff; border-radius:26px; padding:34px; box-shadow:var(--shadow); }
.gallery-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:18px; }
.gallery-grid a { display:block; overflow:hidden; border-radius:22px; box-shadow:var(--shadow-soft); background:#fff; border:1px solid rgba(17,55,30,.08); }
.gallery-grid a:hover { transform:translateY(-3px); box-shadow:var(--shadow); }
.gallery-grid img { width:100%; aspect-ratio:4/3; object-fit:cover; background:#e9e3d5; transition:.25s ease; }
.gallery-grid a:hover img { transform:scale(1.035); }
.gallery-grid a span { display:none !important; }
.photo-only { display:block; border-radius:22px; overflow:hidden; border:1px solid rgba(17,55,30,.08); background:#fff; box-shadow:var(--shadow-soft); }
.photo-only img { width:100%; aspect-ratio:4/3; object-fit:cover; }
.project-detail-grid { display:grid; grid-template-columns:.85fr 1.15fr; gap:26px; align-items:start; }
.details-box { position:sticky; top:104px; }
.detail-list { display:grid; gap:12px; margin-top:18px; }
.detail-item { padding:14px 16px; border-radius:16px; background:#fbfaf5; border:1px solid var(--line); }
.detail-item strong { display:block; color:var(--green-dark); margin-bottom:2px; }
.scope-list { white-space:pre-line; color:var(--muted); }
.cta-row { display:flex; gap:12px; flex-wrap:wrap; margin-top:22px; }
.quote-box { background:linear-gradient(135deg, var(--green), var(--green-dark)); color:#fff; padding:32px; border-radius:26px; box-shadow:var(--shadow); }
.quote-box p { color:rgba(255,255,255,.9); }
.section-head { display:flex; justify-content:space-between; gap:16px; align-items:end; flex-wrap:wrap; margin-bottom:24px; }
.note { background:#fff8e9; border:1px solid #ead8aa; color:#6f5420; border-radius:16px; padding:14px 16px; margin:14px 0; }
@media (max-width:960px) { .hero-grid,.grid-3,.grid-2,.projects-grid,.gallery-grid,.footer-grid,.form-grid,.admin-shell,.project-detail-grid { grid-template-columns:1fr; } .stats { grid-template-columns:1fr 1fr; } .admin-sidebar { min-height:auto; } .details-box { position:static; } }
@media (max-width:760px) { .brand { min-width:0; } .brand span { display:none; } .site-nav { position:absolute; right:16px; top:78px; background:#fff; padding:14px; border-radius:20px; box-shadow:var(--shadow); display:none; flex-direction:column; align-items:stretch; width:min(290px, calc(100% - 32px)); } .site-nav.open { display:flex; } .nav-toggle { display:block; } .stats,.list-grid { grid-template-columns:1fr; } h1 { font-size:2.35rem; } .hero-card img { height:320px; } }

.admin-section-title { margin:26px 0 14px; padding-top:18px; border-top:1px solid var(--line); font-weight:900; color:var(--green-dark); font-size:1.1rem; }
.settings-preview { max-width:180px; max-height:100px; object-fit:contain; margin:10px 0 18px; padding:10px; background:#fbfaf5; border:1px solid var(--line); border-radius:14px; }
.settings-preview.small { max-width:74px; max-height:74px; }
.settings-preview.wide { width:100%; max-width:520px; max-height:220px; object-fit:cover; }
.photo-manage { display:block; overflow:hidden; border-radius:18px; background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-soft); cursor:pointer; }
.photo-manage img { width:100%; aspect-ratio:4/3; object-fit:cover; }
.photo-manage span { display:flex; align-items:center; gap:8px; padding:10px 12px; color:#a32828; font-weight:800; background:#fff; }
.photo-manage input { width:auto; }

/* v5 homepage: removed hero card and uses clean full-width hero */
.hero-minimal { min-height:760px; text-align:center; background-image:linear-gradient(180deg, rgba(8,32,17,.72), rgba(8,32,17,.44), rgba(8,32,17,.76)), var(--hero-bg); }
.hero-minimal-inner { max-width:980px; margin:0 auto; }
.hero-minimal h1 { max-width:900px; margin-left:auto; margin-right:auto; }
.hero-minimal .lead { max-width:760px; margin-left:auto; margin-right:auto; }
.hero-actions { justify-content:center; }
.hero-stats { max-width:840px; margin-left:auto; margin-right:auto; }
@media (max-width:760px) { .hero-minimal { min-height:680px; } }
