.brand img{
  background:transparent;
  padding:0;
  border-radius:0;
  width:220px;
  height:auto;
  box-shadow:none;
  object-fit:contain;
  mix-blend-mode:multiply;
}
.brand{
  background:transparent;
}

:root{
  --bg:#f4f7f2;
  --card:#ffffff;
  --soft:#f9fbf8;
  --text:#162019;
  --muted:#617067;
  --green:#f6fde8;
  --green-dark:#617c31;
  --gold:#f6fde8;
  --anth:#202726;
  --anth-2:#161b1a;
  --border:#dde6dc;
  --danger:#9c2e2e;
  --danger-dark:#7d2424;
  --success:#1f6c3e;
  --shadow:0 14px 34px rgba(20,32,24,.06);
  --radius:20px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top right, rgba(185,151,62,.10), transparent 22%),
    linear-gradient(180deg,#f7faf5 0%, #f1f5ef 100%);
}
a{color:var(--green-dark);text-decoration:none}
img{max-width:100%}

.app-shell{display:flex;min-height:100vh}
.sidebar{
  width:290px;
  background:
    radial-gradient(circle at top, rgba(185,151,62,.16), transparent 30%),
    linear-gradient(180deg,var(--anth),var(--anth-2));
  color:#fff;
  padding:24px 20px;
  position:sticky;
  top:0;
  height:100vh;
  border-right:1px solid rgba(255,255,255,.06);
}
.brand{display:block;margin-bottom:18px;background:transparent}
.brand img{
  background:transparent;
  padding:0;
  border-radius:0;
  width:220px;
  height:auto;
  box-shadow:none;
  object-fit:contain;
  mix-blend-mode:multiply;
}
.brand > div{margin-top:10px}
.brand strong{display:block;font-size:18px}
.brand small{display:block;color:#c3cbc6}

.user-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  padding:14px;
  margin-bottom:20px;
}
.user-role{
  display:inline-flex;
  padding:5px 10px;
  border-radius:999px;
  font-size:12px;
  background:rgba(185,151,62,.15);
  color:#f5df9d;
  border:1px solid rgba(185,151,62,.35);
  margin-bottom:10px;
}
.user-name{font-weight:700}
.user-mail{font-size:13px;color:#c7d0cb}

.nav{display:flex;flex-direction:column;gap:10px}
.nav a{
  color:#eef3ef;
  padding:12px 14px;
  border-radius:14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.04);
}
.nav a:hover{
  background:rgba(255,255,255,.09);
  border-color:rgba(255,255,255,.08);
}
.sidebar-footer{
  position:absolute;
  left:20px;
  right:20px;
  bottom:20px;
  color:#b5beb8;
}
.sidebar-footer small{display:block}
.version-tag{display:block;margin-top:6px;color:rgba(255,255,255,.42);font-size:11px;letter-spacing:.08em}

.content{flex:1;padding:24px 28px 36px}
.topbar{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:16px;
  margin-bottom:18px;
}
.topbar-title{margin:4px 0 0;font-size:28px}
.topbar-meta{
  color:var(--muted);
  font-size:14px;
  background:rgba(255,255,255,.65);
  border:1px solid var(--border);
  border-radius:14px;
  padding:10px 12px;
  backdrop-filter:blur(10px);
}
.eyebrow{
  display:inline-block;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#f6fde8;
  font-weight:700;
}

.page-head{margin-bottom:18px}
.page-head.inline{display:flex;justify-content:space-between;align-items:center;gap:16px}
.page-head h1{margin:4px 0 6px}
.page-head p{margin:0;color:var(--muted)}
.topbar-title,.page-head h1,.hero-copy h2{color:var(--green-dark)}

.hero{
  display:grid;
  grid-template-columns:1.5fr 1fr;
  gap:18px;
  margin-bottom:20px;
}
.hero-copy,
.hero-panel{
  background:var(--card);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  border-radius:24px;
  padding:24px;
}
.hero-copy{background:linear-gradient(135deg, rgba(246,253,232,.10), rgba(97,124,49,.06)), #fff}
.hero-copy h2{margin:8px 0 10px;font-size:30px;line-height:1.1}
.hero-copy p{margin:0 0 16px;color:var(--muted);max-width:700px}
.hero-panel{
  display:grid;
  gap:12px;
  align-content:start;
}
.hero-panel .hero-kpi{min-height:96px}
.hero-kpi{
  background:linear-gradient(180deg,#fdfefc,#f7faf6);
  border:1px solid var(--border);
  border-radius:18px;
  padding:16px 18px;
}
.hero-kpi span{display:block;color:var(--muted);margin-bottom:6px}
.hero-kpi strong{font-size:32px;color:var(--green-dark)}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:20px}
.cards.two-col{grid-template-columns:1fr 1fr}

.card{
  background:rgba(255,255,255,.9);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px;
  box-shadow:var(--shadow);
  backdrop-filter:blur(10px);
}
.card-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px}
.stat span{display:block;color:var(--muted);margin-bottom:10px}
.stat strong{font-size:34px;color:var(--green-dark)}
.card p strong{color:var(--green-dark)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:11px 16px;border-radius:16px;border:1px solid var(--border);
  background:#fff;color:var(--anth);cursor:pointer;font-weight:600;
  box-shadow:0 4px 12px rgba(0,0,0,.03);
}
.btn:hover{transform:translateY(-1px)}
.btn-primary {
  background: linear-gradient(180deg, #8DBE4A 0%, #6FA93A 100%);
  color: #fff;
  border: none;
  box-shadow: 0 4px 12px rgba(111, 169, 58, 0.25);
}
.btn-primary:hover {
  background: linear-gradient(180deg, #7FB33F 0%, #5E9530 100%);
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(111, 169, 58, 0.35);
}
.btn-small{padding:8px 12px;font-size:14px;border-radius:12px}
.btn-danger{background:linear-gradient(180deg,var(--danger),var(--danger-dark));color:#fff;border-color:transparent}

.grid-form{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.grid-form .full{grid-column:1/-1}
label{display:flex;flex-direction:column;gap:8px;font-weight:600}
input,select,textarea{
  width:100%;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  font:inherit;
}
textarea{resize:vertical;min-height:110px}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:rgba(31,108,62,.45);
  box-shadow:0 0 0 4px rgba(31,108,62,.08);
}
select[multiple]{min-height:140px}

.table-wrap{overflow:auto}
.table-wrap table form{margin:0}
.table-wrap td form{display:inline}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:12px 10px;border-bottom:1px solid var(--border);vertical-align:top}
th{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.badge{
  display:inline-flex;
  background:rgba(246,253,232,.12);
  border-color:rgba(246,253,232,.35);
  color:var(--green-dark);
  padding:6px 10px;
  border-radius:999px;
  border:1px solid #d6e5d7;
  font-weight:600
}

.flash{padding:14px 16px;border-radius:16px;margin-bottom:18px}
.flash.success{background:#e8f4ec;color:var(--success);border:1px solid #cbe4d2}
.flash.error{background:#fdecec;color:var(--danger);border:1px solid #f2c9c9}

.dl-grid{display:grid;grid-template-columns:220px 1fr;gap:12px}
.dl-grid dt{font-weight:700;color:var(--muted)}

.signature-box canvas{
  width:100%;
  background:#fff;
  border:2px dashed #cdd9cf;
  border-radius:18px;
  touch-action:none;
}
.signature-preview img{
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:8px;
  max-height:180px;
}
.actions-inline{display:flex;gap:10px;flex-wrap:wrap}
.delete-form{margin:0 0 16px 0}
hr{border:none;border-top:1px solid var(--border);margin:18px 0}

.auth-wrap{display:grid;place-items:center;min-height:100vh;padding:24px}
.auth-card{
  width:min(520px,100%);
  background:rgba(255,255,255,.92);
  padding:40px;
  border-radius:28px;
  border:1px solid var(--border);
  box-shadow:0 20px 48px rgba(21,77,43,.08);
  backdrop-filter:blur(14px);
  text-align:left;
}
.auth-card img{margin-bottom:20px}
.auth-logo{
  width:100%;
  max-width:320px;
  height:auto;
  margin:0 auto 25px auto;
  display:block;
  object-fit:contain;
}
.auth-card p{margin-bottom:20px}

.rapport-toolbar{display:flex;justify-content:space-between;gap:12px;margin-bottom:18px}
.rapport{
  background:#fff;
  border:1px solid var(--border);
  border-radius:24px;
  padding:28px;
  box-shadow:var(--shadow);
}
.rapport-header,.rapport-grid,.rapport-footer{display:flex;gap:18px}
.rapport-header{
  justify-content:space-between;
  align-items:flex-start;
  border-bottom:2px solid #edf0ea;
  padding-bottom:18px;
  margin-bottom:18px
}
.rapport-brand{display:flex;gap:16px;align-items:center}
.rapport-brand img{
  width:84px;height:84px;
  border-radius:18px;
  background:linear-gradient(180deg,#fff,#f7faf6);
  padding:8px;
  border:1px solid var(--border);
}
.rapport-brand h1{margin:0 0 8px}
.rapport-brand p{margin:0 0 4px;color:var(--muted)}
.rapport-grid{margin:0 0 18px}
.rapport-grid .box{flex:1}
.box{
  background:#fcfdfb;
  border:1px solid var(--border);
  border-radius:18px;
  padding:18px
}
.rapport-footer{
  justify-content:space-between;
  border-top:2px solid #edf0ea;
  padding-top:18px;
  color:var(--muted)
}

@media (max-width: 1080px){
  .hero{grid-template-columns:1fr}
}
@media print{
  .no-print,.sidebar,.flash,.btn,.topbar{display:none !important}
  .content{padding:0}
  body{background:#fff}
  .rapport{border:none;padding:0;box-shadow:none}
}
.mobile-menu-toggle{
  display:none;
  position:fixed;
  top:14px;
  left:14px;
  z-index:1100;
  border:none;
  border-radius:14px;
  padding:12px 14px;
  background:linear-gradient(180deg,#8DBE4A 0%, #6FA93A 100%);
  color:#fff;
  font-weight:700;
  box-shadow:0 6px 18px rgba(0,0,0,.18);
}

.mobile-backdrop{
  display:none;
}

@media (max-width: 980px){
  .mobile-menu-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }

  .mobile-backdrop{
    display:block;
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.35);
    z-index:1040;
    opacity:0;
    pointer-events:none;
    transition:opacity .25s ease;
  }

  body.menu-open .mobile-backdrop{
    opacity:1;
    pointer-events:auto;
  }

  .app-shell{
    display:block;
  }

  .sidebar{
    width:280px;
    height:100vh;
    position:fixed;
    top:0;
    left:0;
    bottom:0;
    z-index:1050;
    transform:translateX(-100%);
    transition:transform .25s ease;
    overflow-y:auto;
    border-right:none;
    border-bottom:none;
  }

  body.menu-open .sidebar{
    transform:translateX(0);
  }

  .sidebar-footer{
    position:static;
    margin-top:18px;
  }

  .content{
    padding:72px 16px 16px;
  }

  .cards,.cards.two-col,.grid-form,.rapport-grid{
    grid-template-columns:1fr;
    display:grid;
  }

  .page-head.inline,.topbar,.rapport-toolbar{
    display:block;
  }

  .topbar-meta{
    margin-top:10px;
    display:inline-flex;
  }

  .dl-grid{
    grid-template-columns:1fr;
  }
}
.upload-gallery{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:16px;
}
.upload-item{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.upload-item img{
  width:100%;
  height:180px;
  object-fit:cover;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
}
.upload-caption{
  font-size:13px;
  color:var(--muted);
  word-break:break-word;
}
.file-box{
  min-height:180px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--border);
  border-radius:14px;
  background:#fff;
  padding:12px;
  text-align:center;
}

.permission-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:10px;
  margin-top:8px;
}
.permission-item{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:12px;
  background:#fff;
}
.permission-item input{
  width:auto;
}

.permission-help{
  margin-top:8px;
  margin-bottom:14px;
  color:var(--muted);
  font-weight:400;
}
.permission-groups{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:16px;
  margin-top:8px;
}
.permission-group-card{
  border:1px solid var(--border);
  border-radius:16px;
  background:#fff;
  padding:14px;
}
.permission-group-card h3{
  margin:0 0 12px 0;
  color:var(--green-dark);
  font-size:16px;
}
.permission-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}
.permission-item{
  display:flex;
  flex-direction:row;
  align-items:flex-start;
  gap:10px;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:12px;
  background:#fff;
}
.permission-item input{
  width:auto;
  margin-top:2px;
}
.permission-text{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.permission-text small{
  color:var(--muted);
  font-weight:400;
  line-height:1.35;
}
