:root{
  --primary:#2D5016;
  --primary-700:#244012;
  --secondary:#8FBC8F;
  --secondary-200:#D4E7D4;
  --secondary-100:#E8F3E8;
  --secondary-50:#F4F9F4;
  --accent:#6B9E6F;
  --bg:#FAFAFA;
  --white:#FFFFFF;
  --text:#1F2937;
  --muted:#6B7280;
  --border:#E5E7EB;
  --ring:rgba(45,80,22,0.18);
  --shadow:0 2px 8px rgba(31,41,55,0.06);
  --shadow-lg:0 12px 24px rgba(31,41,55,0.12);
  --radius:10px;
  --space-xs:0.375rem;
  --space-sm:0.75rem;
  --space-md:1rem;
  --space-lg:1.5rem;
  --space-xl:2rem;
  --space-2xl:3rem;
  --maxw:1200px;
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;
  color:var(--text);
  background:var(--bg);
  line-height:1.7;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none;transition:color .2s ease,opacity .2s ease}
a:hover{opacity:.9}
a:focus{outline:2px solid var(--ring);outline-offset:2px;border-radius:4px}

h1,h2,h3,h4,h5,h6{
  color:var(--primary);
  line-height:1.25;
  letter-spacing:.01em;
  margin:0 0 var(--space-md) 0;
  font-weight:700;
}
h1{font-size:clamp(2rem,5vw,2.75rem)}
h2{font-size:clamp(1.5rem,3.5vw,2rem)}
h3{font-size:clamp(1.25rem,2.5vw,1.5rem)}
h4{font-size:1.125rem}
h5{font-size:1rem}
h6{font-size:.9rem;text-transform:uppercase;letter-spacing:.04em}

p{margin:0 0 var(--space-md) 0}
small{font-size:.875rem;color:var(--muted)}

hr{border:0;border-top:1px solid var(--border);margin:var(--space-xl) 0}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--space-lg)}
.section{padding:var(--space-2xl) 0}
.section-sm{padding:var(--space-xl) 0}
.section-bg-white{background:var(--white)}
.section-bg-alt{background:#F0F8F0}
.section-bg-subtle{background:#FAFAFA}

.badge{
  display:inline-flex;align-items:center;gap:.5ch;
  padding:.25rem .5rem;
  border-radius:999px;
  background:var(--secondary-100);
  color:var(--primary);
  border:1px solid var(--secondary-200);
  font-size:.8125rem;
  font-weight:600;
}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5ch;
  padding:.75rem 1rem;
  border:1px solid transparent;
  border-radius:8px;
  background:var(--secondary);
  color:var(--primary);
  font-weight:600;
  text-align:center;
  cursor:pointer;
  transition:all .2s ease;
  user-select:none;
  min-height:44px;
}
.btn:hover{background:var(--secondary-200);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn:focus{outline:3px solid var(--ring);outline-offset:2px}
.btn--ghost{
  background:transparent;border-color:var(--border);color:var(--primary)
}
.btn--ghost:hover{background:var(--secondary-50)}
.btn--dark{background:var(--primary);color:#fff}
.btn--dark:hover{background:var(--primary-700)}
.btn--sm{padding:.5rem .75rem;min-height:38px;font-size:.9rem}
.btn--lg{padding:.875rem 1.25rem;font-size:1.05rem}

.card{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
  transition:box-shadow .2s ease,transform .2s ease,border-color .2s ease;
}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.card__body{padding:var(--space-lg)}
.card__header{padding:var(--space-lg) var(--space-lg) var(--space-md) var(--space-lg);border-bottom:1px solid var(--border)}
.card__footer{padding:var(--space-md) var(--space-lg) var(--space-lg) var(--space-lg);border-top:1px solid var(--border)}
.card--borderless{border-color:transparent}

.input,select,textarea{
  width:100%;
  padding:.75rem .875rem;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:8px;
  color:var(--text);
  transition:border-color .2s ease,box-shadow .2s ease;
  min-height:44px;
}
textarea{min-height:120px;resize:vertical}
.input:focus,select:focus,textarea:focus{
  border-color:var(--primary);
  outline:none;
  box-shadow:0 0 0 4px var(--ring)
}
.input::placeholder{color:var(--muted)}

.label{display:block;font-weight:600;margin:0 0 .5rem 0;color:var(--primary)}
.form-group{margin-bottom:var(--space-lg)}

.grid{display:grid;gap:var(--space-lg)}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}

.row{display:flex;flex-wrap:wrap;gap:var(--space-lg)}
.row > *{flex:1 1 0}

.header{
  position:sticky;top:0;z-index:40;
  background:var(--white);
  border-bottom:1px solid var(--border);
  backdrop-filter:saturate(180%) blur(8px)
}
.header .inner{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) 0}
.brand{display:flex;align-items:center;gap:.75rem;color:var(--primary);text-decoration:none;font-weight:700;font-size:1.125rem}
.brand .logo{
  width:36px;height:36px;border-radius:8px;
  background:linear-gradient(135deg,var(--secondary) 0%,var(--primary) 100%);
  box-shadow:0 4px 10px rgba(45,80,22,0.25)
}

.nav{display:flex;align-items:center;gap:1rem}
.nav a{
  color:var(--text);padding:.5rem .75rem;border-radius:6px;font-weight:500;transition:background .2s ease,color .2s ease
}
.nav a:hover{background:var(--secondary-50);color:var(--primary)}
.nav .btn{margin-left:.25rem}

.mobile-toggle{display:none;background:transparent;border:0;padding:.5rem;border-radius:8px}
.mobile-toggle:focus{outline:3px solid var(--ring);outline-offset:2px}

@media (max-width: 768px){
  .nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--white);border-bottom:1px solid var(--border);padding:var(--space-lg);flex-direction:column;align-items:flex-start}
  .nav.open{display:flex}
  .mobile-toggle{display:inline-flex}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .row{flex-direction:column}
}

.table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.table th,.table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border);vertical-align:top}
.table th{background:var(--secondary-50);color:var(--primary);font-weight:700}
.table tr:last-child td{border-bottom:0}
.table--striped tbody tr:nth-child(even){background:#FAFAFA}
.table--hover tbody tr:hover{background:var(--secondary-50)}

.alert{
  border:1px solid var(--border);
  border-left:4px solid var(--secondary);
  border-radius:8px;
  padding:var(--space-lg);
  background:var(--secondary-50);
  color:var(--text);
}
.alert--error{border-left-color:#DC2626;background:#FEF2F2}
.alert--warning{border-left-color:#D97706;background:#FFFBEB}
.alert--success{border-left-color:#059669;background:#ECFDF5}

.kicker{font-size:.9375rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem}

.callout{
  border:1px solid var(--secondary-200);
  background:var(--secondary-50);
  border-left:4px solid var(--secondary);
  border-radius:8px;
  padding:var(--space-lg)
}

blockquote{
  margin:0 0 var(--space-lg) 0;
  padding:var(--space-lg);
  background:var(--white);
  border-left:4px solid var(--primary);
  border-radius:8px;
  box-shadow:var(--shadow);
  font-style:italic
}

.footer{
  background:var(--primary);
  color:#E5F0E5;
  padding:var(--space-2xl) 0 var(--space-lg) 0;
}
.footer a{color:#CFE6CF}
.footer .copyright{margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid rgba(255,255,255,.2);font-size:.9375rem}

.hero{
  background:linear-gradient(180deg,#FFFFFF 0%,#F0F8F0 100%);
  border-bottom:1px solid var(--border);
  padding:calc(var(--space-2xl) + 1.25rem) 0 var(--space-2xl) 0;
}
.hero .title{color:var(--primary);margin-bottom:var(--space-md)}
.hero .lead{color:var(--text);max-width:60ch}

.divider{height:1px;background:var(--border);margin:var(--space-xl) 0}

.tooltip{position:relative;display:inline-flex}
.tooltip::after{
  content:attr(data-tooltip);
  position:absolute;bottom:100%;left:50%;transform:translateX(-50%) translateY(-6px);
  background:rgba(17,24,39,.98);color:#fff;padding:.5rem .75rem;border-radius:6px;font-size:.8125rem;
  white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;
}
.tooltip:hover::after{opacity:1;transform:translateX(-50%) translateY(-8px)}

.skip-link{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden
}
.skip-link:focus{
  position:fixed;left:var(--space-lg);top:var(--space-lg);width:auto;height:auto;padding:.5rem .75rem;background:#000;color:#fff;z-index:9999;border-radius:6px
}

.muted{color:var(--muted)}
.text-center{text-align:center}
.text-right{text-align:right}

.section-title{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:var(--space-lg)}
.section-title .actions{display:flex;gap:.5rem;align-items:center}

.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}

blockquote{border-left-color:var(--secondary)}
blockquote strong{color:var(--primary)}@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
}


/* Cookie Banner Additional Styles for Tailwind */
.cookie-banner-hover-effect:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

@media (prefers-reduced-motion: reduce) {
    .cookie-banner-hover-effect:hover {
        transform: none;
    }
}