:root{
  --espresso:#2C1B10;
  --bronze:#8B5E3C;
  --sand:#D4A882;
  --almond:#EDD5B8;
  --cream:#F5EDE4;
  --gold:#C9A84C;
  --gold-dark:#9B7A2A;
  --gold-light:#E8CB7A;
  --text:#1A0F08;
  --text-soft:#5C3D24;
  --text-muted:#8B6A4A;
  --surface:rgba(245,237,228,0.84);
  --surface-strong:rgba(245,237,228,0.95);
  --surface-dark:rgba(30,18,11,0.92);
  --line:rgba(201,168,76,0.22);
  --line-strong:rgba(201,168,76,0.4);
  --success:#547A5A;
  --danger:#8D4F45;
  --shadow:0 22px 58px rgba(44,27,16,0.12);
  --radius:6px;
  --transition:0.35s cubic-bezier(0.25,0.46,0.45,0.94);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  min-height:100vh;
  font-family:"Jost",sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top right, rgba(212,168,130,0.25), transparent 26%),
    linear-gradient(135deg, var(--cream) 0%, var(--almond) 100%);
}

body.login-page{
  background:
    linear-gradient(180deg, rgba(245,237,228,0.98), rgba(237,213,184,0.96));
}

body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:0.28;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
}

body.dark{
  --cream:#1A0F08;
  --almond:#24150D;
  --text:#F5EDE4;
  --text-soft:#D4A882;
  --text-muted:#AB8160;
  --surface:rgba(26,15,8,0.82);
  --surface-strong:rgba(26,15,8,0.92);
  --surface-dark:rgba(10,6,4,0.96);
  --line:rgba(201,168,76,0.18);
  --line-strong:rgba(201,168,76,0.3);
  --shadow:0 24px 68px rgba(0,0,0,0.34);
}

a{color:inherit;text-decoration:none}
button,input,select{font:inherit}

.app-shell{
  width:min(1360px, calc(100% - 28px));
  margin:0 auto;
  position:relative;
  z-index:1;
}

.topbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  padding:18px 24px;
  margin-top:18px;
  background:var(--surface);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  backdrop-filter:blur(18px) saturate(1.15);
  position:sticky;
  top:0;
  z-index:20;
}

.brand{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:6px;
}

.brand-logo{
  display:block;
  height:34px;
  width:auto;
  object-fit:contain;
  transform-origin:left center;
}

.brand-logo-login{
  height:48px;
}

.brand strong,.stat-value,.hero-title,.section-title,.page-title,.card-title{
  font-family:"Cormorant Garamond",serif;
}

.brand strong{
  font-size:1.6rem;
  color:var(--bronze);
  letter-spacing:0.04em;
}

.brand strong span,
.page-title em,
.hero-title em,
.section-title em,
.card-title em{
  color:var(--gold);
  font-style:italic;
}

.brand small,.eyebrow,.kicker,.table-head th,.field label,.pill{
  text-transform:uppercase;
  letter-spacing:0.15em;
  font-size:0.68rem;
}

.brand small,.field label,.muted,.table-head th{color:var(--text-muted)}

.brand small{
  padding-left:8px;
  line-height:1.2;
}

.nav-actions,.hero-actions,.inline-actions{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.inline-actions.compact{
  gap:8px;
}

.btn,.btn-secondary,.btn-outline{
  border:none;
  cursor:pointer;
  border-radius:999px;
  padding:0.92rem 1.25rem;
  transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition), color var(--transition), background var(--transition);
}

.btn{
  background:linear-gradient(135deg, var(--gold-dark), var(--gold));
  color:#fff;
  box-shadow:0 12px 30px rgba(201,168,76,0.24);
}

.btn:hover,.btn-secondary:hover,.action-card:hover{
  transform:translateY(-2px);
}

.btn-secondary{
  background:var(--surface-dark);
  color:#F5EDE4;
  border:1px solid rgba(201,168,76,0.15);
}

.btn-outline{
  background:transparent;
  color:var(--text-soft);
  border:1px solid var(--line);
}

.btn-outline:hover{
  color:var(--gold);
  border-color:var(--line-strong);
}

.btn-small{
  padding:0.62rem 0.9rem;
  font-size:0.78rem;
  border-radius:999px;
}

.page-grid,.hero-grid,.cards-4,.cards-3,.dashboard-grid,.employee-grid,.auth-grid{
  display:grid;
  gap:22px;
}

.hero-grid{grid-template-columns:1.1fr 0.9fr;padding:42px 0 24px}
.dashboard-grid{grid-template-columns:1.1fr 0.9fr}
.employee-grid{grid-template-columns:1fr 0.95fr}
.cards-4{grid-template-columns:repeat(4, minmax(0,1fr))}
.cards-3{grid-template-columns:repeat(3, minmax(0,1fr))}
.auth-grid{grid-template-columns:1.05fr 0.95fr;min-height:calc(100vh - 130px);align-items:center}

.panel,.hero-panel,.hero-side,.summary-card,.table-card,.action-card,.timeline-card,.auth-card,.feature-card{
  background:var(--surface);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}

.panel.is-editing{
  border-color:var(--line-strong);
  box-shadow:0 0 0 3px rgba(201,168,76,0.12), var(--shadow);
}

.hero-panel,.hero-side,.panel,.table-card,.timeline-card,.auth-card{padding:30px}

.dashboard-hero{
  position:relative;
  overflow:hidden;
  display:grid;
  gap:28px;
  padding:36px;
  margin:34px 0 30px;
  background:linear-gradient(145deg, rgba(245,237,228,0.96), rgba(255,249,242,0.9));
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}

.dashboard-hero::before{
  content:"";
  position:absolute;
  right:-110px;
  top:-120px;
  width:340px;
  height:340px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(201,168,76,0.18), transparent 70%);
  pointer-events:none;
}

.dashboard-hero-top{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0, 1.35fr) minmax(280px, 0.72fr);
  gap:24px;
  align-items:start;
}

.dashboard-hero-copy{
  max-width:60ch;
}

.dashboard-mini-panel{
  padding:22px 24px;
  background:rgba(255,255,255,0.42);
  border:1px solid rgba(201,168,76,0.18);
}

.dashboard-mini-panel .card-title{
  margin-bottom:8px;
}

.hero-panel{
  position:relative;
  overflow:hidden;
  min-height:500px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}

.hero-panel::before{
  content:"";
  position:absolute;
  right:-80px;
  top:-90px;
  width:320px;
  height:320px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(201,168,76,0.16), transparent 70%);
}

.hero-title{
  font-size:clamp(3rem, 5vw, 4.7rem);
  line-height:0.95;
  max-width:10ch;
  margin-bottom:18px;
}

.hero-title.fixed-two-lines{
  max-width:11ch;
}

.hero-title-admin{
  max-width:18ch;
  margin-bottom:12px;
}

.hero-title-admin span{
  display:block;
}

.hero-copy,.section-copy,.card-copy,.timeline-copy,.auth-copy{
  line-height:1.75;
  color:var(--text-soft);
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--gold);
  margin-bottom:16px;
}

.eyebrow::before{
  content:"";
  width:24px;
  height:1px;
  background:var(--gold);
}

.stat-row{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:14px;
  padding-top:24px;
  border-top:1px solid var(--line);
}

.dashboard-stat-row{
  position:relative;
  z-index:1;
  gap:18px;
}

.dashboard-stat-row > div{
  padding:18px 20px 14px;
  background:rgba(255,255,255,0.34);
  border:1px solid rgba(201,168,76,0.14);
}

.stat-value{
  display:block;
  font-size:2.1rem;
  color:var(--gold);
}

.stat-label{
  display:block;
  margin-top:6px;
  color:var(--text-muted);
  font-size:0.72rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
}

.page-section{padding:18px 0}

.section-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:18px;
  margin-bottom:18px;
}

.section-title,.page-title{font-size:2.5rem;line-height:1}
.section-copy{max-width:54ch}

.admin-head{
  align-items:flex-end;
  gap:32px;
  margin-bottom:30px;
}

.admin-head-copy{
  max-width:880px;
}

.admin-head-note{
  max-width:42ch;
}

.summary-card,.feature-card,.action-card{
  padding:24px;
  position:relative;
  overflow:hidden;
}

.summary-card::before,.action-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(201,168,76,0.08), transparent 62%);
  opacity:0;
  transition:opacity var(--transition);
}

.summary-card:hover::before,.action-card:hover::before{opacity:1}

.card-title{
  font-size:1.65rem;
  margin:12px 0 10px;
}

.card-value{
  display:block;
  font-size:2rem;
  color:var(--gold);
  margin-bottom:6px;
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:0.5rem 0.8rem;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(201,168,76,0.08);
  color:var(--gold-dark);
}

.pill.success{color:var(--success);background:rgba(84,122,90,0.1);border-color:rgba(84,122,90,0.25)}
.pill.danger{color:var(--danger);background:rgba(141,79,69,0.1);border-color:rgba(141,79,69,0.25)}

.field-group,.login-form,.toolbar,.employee-stats,.timeline{display:grid;gap:16px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

.field{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.field input,.field select{
  width:100%;
  background:var(--surface-strong);
  color:var(--text);
  border:1px solid var(--line);
  border-radius:6px;
  padding:0.95rem 1rem;
  outline:none;
  transition:border-color var(--transition), background var(--transition);
}

.field input:focus,.field select:focus{
  border-color:var(--line-strong);
  background:rgba(201,168,76,0.06);
}

.auth-card.dark{
  background:linear-gradient(145deg, rgba(44,27,16,0.96), rgba(18,11,7,0.96));
  border:1px solid rgba(201,168,76,0.14);
  color:#F5EDE4;
}

.auth-card.dark .auth-copy,
.auth-card.dark .muted{
  color:rgba(237,213,184,0.76);
}

.login-visual{
  display:grid;
  gap:14px;
}

.visual-line{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  border:1px solid rgba(201,168,76,0.15);
  background:rgba(245,237,228,0.04);
}

.avatar{
  width:62px;
  height:62px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--sand), var(--bronze));
  color:#fff;
  font-family:"Cormorant Garamond",serif;
  font-size:1.7rem;
}

.profile-head{
  display:flex;
  align-items:center;
  gap:14px;
}

.clock-card{
  padding:30px;
  background:
    radial-gradient(circle at top right, rgba(201,168,76,0.12), transparent 28%),
    linear-gradient(180deg, rgba(245,237,228,0.98), rgba(237,213,184,0.96));
  border:1px solid rgba(201,168,76,0.22);
  box-shadow:var(--shadow);
}

.clock-card .eyebrow,
.clock-card .muted,
.clock-card .card-copy{
  color:var(--text-soft);
}

.clock-card .page-title,
.clock-card .card-title{
  color:var(--text);
}

.clock-card .pill{
  background:rgba(201,168,76,0.12);
}

.clock-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  margin:20px 0 24px;
  padding:18px 20px;
  border:1px solid rgba(201,168,76,0.18);
  background:rgba(255,255,255,0.28);
}

.clock-number{
  font-family:"Cormorant Garamond",serif;
  font-size:4.4rem;
  color:var(--gold-dark);
  line-height:0.9;
}

.clock-meta{
  text-align:right;
  color:var(--text-muted);
  line-height:1.6;
  font-size:0.86rem;
  max-width:28ch;
}

.action-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.action-card{
  min-height:138px;
  cursor:pointer;
  text-align:left;
  background:rgba(255,255,255,0.48);
  border:1px solid rgba(201,168,76,0.18);
  box-shadow:none;
}

.action-card .card-title{
  margin-top:10px;
  margin-bottom:8px;
  font-size:1.9rem;
  line-height:1;
}

.action-card .card-copy{
  color:var(--text-muted);
  font-size:1rem;
}

.action-card:hover{
  border-color:rgba(201,168,76,0.34);
  background:rgba(255,255,255,0.68);
  box-shadow:0 16px 34px rgba(44,27,16,0.1);
}

.action-card:disabled,
.action-card.is-disabled{
  cursor:not-allowed;
  opacity:0.46;
  transform:none;
  box-shadow:none;
}

.action-card:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:2px;
}

.employee-summary-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin:18px 0 22px;
}

.summary-line{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:14px 16px;
  background:rgba(255,255,255,0.28);
  border:1px solid rgba(201,168,76,0.14);
}

.summary-line strong{
  color:var(--text);
  font-weight:500;
}

.summary-line-full{
  grid-column:1 / -1;
}

.table-card table{
  width:100%;
  border-collapse:collapse;
  margin-top:16px;
}

.insights-card{
  min-height:360px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}

.audit-card table{
  margin-top:8px;
}

.audit-card .empty-state{
  margin-top:18px;
}

.table-card th,.table-card td{
  text-align:left;
  padding:14px 10px;
  border-bottom:1px solid var(--line);
  font-size:0.94rem;
}

.table-card td{color:var(--text-soft)}
.table-card td strong{color:var(--text);font-weight:500}
.table-card td .subline{
  display:block;
  margin-top:4px;
  font-size:0.8rem;
  color:var(--text-muted);
  line-height:1.5;
}

.toolbar{
  grid-template-columns:1.3fr auto auto;
  align-items:end;
}

.toolbar-wide{
  grid-template-columns:minmax(220px, 1.5fr) minmax(180px, 0.9fr) minmax(180px, 0.9fr) auto auto auto;
}

.tab-nav,
.range-nav{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.tab-btn,
.range-btn{
  border:1px solid var(--line);
  background:transparent;
  color:var(--text-soft);
  border-radius:999px;
  padding:0.75rem 1rem;
  cursor:pointer;
  transition:all var(--transition);
}

.tab-btn.active,
.range-btn.active{
  background:linear-gradient(135deg, var(--gold-dark), var(--gold));
  color:#fff;
  border-color:transparent;
  box-shadow:0 12px 30px rgba(201,168,76,0.2);
}

.tab-panel{
  display:none;
}

.tab-panel.active{
  display:block;
}

.dashboard-info-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
}

.dashboard-info-grid-wide{
  position:relative;
  z-index:1;
  gap:20px;
}

.dashboard-info-grid-wide .summary-card{
  min-height:250px;
  background:rgba(255,255,255,0.38);
}

.modal-backdrop{
  position:fixed;
  inset:0;
  background:rgba(18,11,7,0.45);
  backdrop-filter:blur(6px);
  display:none;
  align-items:center;
  justify-content:center;
  padding:20px;
  z-index:100;
}

.modal-backdrop.open{
  display:flex;
}

.modal-card{
  width:min(560px, 100%);
  background:var(--surface-strong);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  padding:28px;
}

.modal-card p{
  color:var(--text-soft);
  line-height:1.75;
}

.search-input{
  padding:0.92rem 1rem;
  border-radius:6px;
  border:1px solid var(--line);
  background:var(--surface-strong);
  color:var(--text);
}

.alert-list{
  display:grid;
  gap:14px;
  margin-top:10px;
}

.alert-item{
  position:relative;
  padding:18px 20px 18px 26px;
  border:1px solid rgba(201,168,76,0.18);
  background:linear-gradient(135deg, rgba(255,255,255,0.5), rgba(255,255,255,0.28));
  color:var(--text-soft);
  line-height:1.7;
  box-shadow:0 10px 24px rgba(44,27,16,0.05);
}

.alert-item::before{
  content:"";
  position:absolute;
  left:0;
  top:14px;
  bottom:14px;
  width:3px;
  background:linear-gradient(180deg, var(--gold), rgba(201,168,76,0.18));
}

.empty-state{
  margin-top:14px;
  padding:22px 24px;
  border:1px dashed var(--line-strong);
  background:rgba(255,255,255,0.36);
  color:var(--text-soft);
  line-height:1.7;
  display:none;
}

.empty-state.show{display:block}

.audit-card .empty-state.show{
  display:flex;
  align-items:center;
  min-height:114px;
}

.timeline{
  margin-top:18px;
  position:relative;
}

.timeline::before{
  content:"";
  position:absolute;
  left:18px;
  top:0;
  bottom:0;
  width:1px;
  background:linear-gradient(to bottom, var(--gold), transparent);
}

.timeline-item{
  display:grid;
  grid-template-columns:36px 1fr;
  gap:16px;
}

.timeline-point{
  width:36px;
  height:36px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--gold-dark), var(--gold));
  color:#fff;
  font-size:0.72rem;
  position:relative;
  z-index:1;
}

.footer-note{
  margin:28px 0 60px;
  padding:18px 22px;
  background:rgba(44,27,16,0.94);
  border:1px solid rgba(201,168,76,0.15);
  color:rgba(237,213,184,0.8);
  line-height:1.75;
  box-shadow:var(--shadow);
}

.login-shell{
  width:min(520px, calc(100% - 28px));
  margin:0 auto;
  position:relative;
  z-index:1;
}

.login-minimal{
  min-height:100vh;
  display:grid;
  place-items:center;
}

.login-card-minimal{
  padding:34px;
  background:var(--surface-strong);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}

.login-header{
  text-align:center;
  margin-bottom:24px;
}

.login-header .brand{
  align-items:center;
  gap:10px;
}

.login-header .brand small{
  padding-left:0;
  text-align:center;
}

.login-header p{
  margin-top:12px;
  color:var(--text-soft);
  line-height:1.7;
}

.login-form-minimal{
  display:grid;
  gap:16px;
}

.login-footer-note{
  margin-top:16px;
  text-align:center;
  color:var(--text-muted);
  font-size:0.88rem;
  line-height:1.6;
}

@media (max-width: 1100px){
  .hero-grid,.dashboard-grid,.employee-grid,.auth-grid,.cards-4,.cards-3,.dashboard-hero-top{grid-template-columns:1fr}
}

@media (max-width: 760px){
  .app-shell{width:min(100% - 18px, 1360px)}
  .topbar{padding:16px 18px}
  .hero-panel,.hero-side,.panel,.table-card,.timeline-card,.auth-card,.clock-card,.dashboard-hero{padding:22px}
  .field-row,.action-grid,.stat-row,.toolbar,.dashboard-info-grid,.employee-summary-grid{grid-template-columns:1fr}
  .section-head,.clock-row{flex-direction:column;align-items:flex-start}
  .clock-meta{text-align:left}
  .clock-number{font-size:3.5rem}
  .hero-title{font-size:2.8rem}
  .hero-title-admin{max-width:11ch}
}
