/* === CSS RESET & NORMALIZE === */
html,body,div,section,header,footer,h1,h2,h3,h4,h5,h6,p,ul,ol,li,figure,img,nav,a,button,form,input,textarea,label,main {margin:0;padding:0;box-sizing:border-box;}
ul,ol{list-style:none;}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;transition:color .2s;}
button,input,textarea{font:inherit;border:none;background:none;outline:none;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
body { background: #F3EFEA; color: #3F4D40; font-family: 'Montserrat', Arial, sans-serif; font-size:16px; line-height:1.7; min-height:100vh; }

/* === BRAND COLORS & FONTS === */
:root {
  --primary: #3F4D40;
  --secondary: #A68C55;
  --accent: #F3EFEA;
  --danger: #e95e5e;
  --art-pink: #E76F76;
  --art-purple: #7A4988;
  --art-blue: #46AEB3;
  --art-yellow: #FFD669;
  --text-light: #fff;
  --text-dark: #282827;
  --radius: 18px;
}

/* === TYPOGRAPHY === */
h1,h2,h3,h4 { font-family: 'Lora', Georgia, serif; color: var(--primary); margin-bottom: 14px; letter-spacing:-0.7px;}
h1 { font-size: 2.4rem; font-weight:700; line-height:1.08; margin-bottom:22px;}
h2 { font-size: 1.6rem; font-weight:600; margin-bottom:18px;}
h3 { font-size: 1.18rem; font-weight:600; margin-bottom:8px;}
h4 { font-size: 1rem; font-weight:500; }
p,li { font-size:1rem; margin-bottom:12px; color: var(--primary);}
strong {color:var(--art-purple);}

/* === CONTAINER & LAYOUT === */
.container { width:100%; max-width:1140px; margin:0 auto; padding:0 20px; }
.flex-align { display:flex; align-items:center; justify-content:space-between; gap: 20px; }
.content-wrapper { display:flex; flex-direction:column; align-items:flex-start; gap:18px; padding: 0;}

.section { margin-bottom:60px; padding:40px 20px; border-radius:var(--radius); background:rgba(255,255,255,0.89); box-shadow:0 2px 18px 0 rgba(167,140,85,0.05); position:relative;}
@media (max-width:768px) { .section { padding:30px 6px; margin-bottom:40px; } }

.card-container { display:flex; flex-wrap:wrap; gap:24px; }
.card { margin-bottom:20px; position:relative; background:#fff; border-radius:var(--radius); box-shadow:0 3px 14px 1px rgba(71,78,65,.09); transition:box-shadow .3s; }
.card:hover { box-shadow:0 7px 26px 2px rgba(167,140,85,0.14); }

.content-grid { display:flex; flex-wrap:wrap; gap:20px; justify-content:space-between; }
.text-image-section { display:flex; align-items:center; gap:30px; flex-wrap:wrap; }
@media (max-width:768px) { .text-image-section { flex-direction:column; gap: 20px; } }

.testimonial-card { display:flex; align-items:center; gap:20px; padding:20px; background:#fff; border-radius:var(--radius); box-shadow:0 2px 10px 0 rgba(71,78,65,0.06); margin-bottom:24px; position:relative; }
.testimonial-card p { font-size:1.08rem; font-style:italic; color:var(--primary); margin:0; }
.testimonial-card span { color:var(--secondary); font-weight:600; margin-left:6px; }

.feature-list, .feature-item { display:flex; flex-wrap:wrap; gap:20px; }
.feature-list li, .feature-item { display:flex; flex-direction:column; align-items:flex-start; gap:15px; background:#fff; border-radius:var(--radius); padding:24px 18px; box-shadow:0 1.5px 10px 0 rgba(71,78,65,0.05); min-width: 230px; flex: 1 0 240px; margin-bottom:22px; transition:transform .14s,box-shadow .14s; }
.feature-list li:hover { transform:translateY(-6px) scale(1.028); box-shadow:0 7px 28px 0 rgba(231,111,118,0.10); }

/* === HEADER & NAVIGATION === */
header { background:#FFF; box-shadow:0 1.5px 18px 0 rgba(63,77,64,0.03); padding:0; position:relative; z-index:22; }
header .container { min-height:74px; }
nav { display:flex; gap:18px; align-items:center; }
nav a { color:var(--primary); font-weight:600; padding:8px 6px; border-radius:6px; transition:background .18s,color .18s; }
nav a:hover, nav a:focus { background:var(--art-pink); color:var(--text-light); }
.button.primary, .button {border-radius: 23px;padding:12px 26px;font-weight:700;font-size:1.04rem;cursor:pointer;transition:background .21s, box-shadow .19s, color .14s;box-shadow:0 2px 16px 0 rgba(231,111,118,.05),0 0.5px 1px 0 rgba(71,78,65,.09);display:inline-block; border:none; }
.button.primary {background:var(--art-pink);color:#fff; }
.button.primary:hover, .button.primary:focus { background:var(--art-purple); color:#fff; }
.button {background:var(--secondary);color:#fff;}
.button:hover, .button:focus { background:var(--art-yellow); color:var(--primary); }

/* === MOBILE BURGER MENU === */
.mobile-menu-toggle { display:none; background:none;color:var(--art-pink);font-size:2.1rem;border:none;line-height:1; margin-left:16px; padding:4px 10px; cursor:pointer; }
@media (max-width: 992px) {
  nav { display:none; }
  .mobile-menu-toggle { display:inline-block; }
}
.mobile-menu { display:none; position:fixed; top:0;left:0;width:100vw;height:100vh;z-index:900; background:rgba(63,77,64,0.97); transition:transform .41s cubic-bezier(0.68,-0.55,0.27,1.55); transform:translateX(100%); flex-direction:column; }
.mobile-menu.open { display:flex; transform:translateX(0); }
.mobile-menu-close { position:absolute; top:24px; right:32px; background:none; border:none; font-size:2.3rem; color:var(--art-yellow); cursor:pointer; z-index:980;}
.mobile-nav { display:flex; flex-direction:column; align-items:center; justify-content:center; height:100%; width:100%; gap:30px; }
.mobile-nav a { font-size:1.28rem; color:var(--accent); font-family:'Lora',Georgia,serif; font-weight:700; letter-spacing:0.6px; border-radius:10px; padding:16px 28px; transition:background .13s,color .13s; }
.mobile-nav a:hover, .mobile-nav a:focus { background:var(--art-pink); color:var(--text-light); }
@media (max-width: 768px) {
  header .container { flex-direction:row; flex-wrap:wrap; }
}
@media (max-width: 992px) {
  .mobile-menu { display:flex; }
}

/* === FOOTER === */
footer { background:var(--primary); color:var(--accent); margin-top:40px; padding:0 0 30px 0; position:relative; }
.footer-grid { display:flex; flex-wrap:wrap; gap:28px; align-items:flex-start; justify-content:space-between; padding:36px 0 0 0; }
footer nav { display:flex; flex-direction:column; gap:6px; }
footer nav a { color:var(--art-yellow); font-size:1rem; font-family:'Montserrat',Arial,sans-serif; margin-bottom:4px; transition:color .19s; }
footer nav a:hover, footer nav a:focus { color:var(--art-pink); font-weight:700; }
.footer-social { display:flex; gap:14px; align-items:center; margin-top:12px; }
.footer-social a { display:inline-block; transition:transform .19s; }
.footer-social a:hover { transform:scale(1.16) rotate(-6deg); }
footer img { max-height:36px; margin-bottom:10px; }
@media (max-width: 768px) {
  .footer-grid { flex-direction:column; gap:18px; align-items:flex-start; }
}

/* === ARTISTIC ELEMENTS === */
.section:nth-of-type(2n) { background:rgba(231,111,118,0.07); }
.section:nth-of-type(3n) { background:rgba(70,174,179,0.07); }
.section:nth-of-type(4n) { background:rgba(255,214,105,0.07); }

.feature-list img,
.feature-item img { max-width:42px; max-height:42px; border-radius:50%; background:var(--art-yellow); padding:7px; border:2.5px dashed var(--art-pink); box-shadow:0 3.5px 13px 0 rgba(231,111,118,0.05); margin-bottom:10px; }

@media (max-width:600px) {
  .feature-list,.feature-item { gap:12px; }
  .feature-list li,.feature-item { padding:16px 8px; min-width:120px; }
}

/* === BREADCRUMBS, PRICING, INFO === */
.pricing { color: var(--art-pink); font-weight:600; font-size:1.14rem; margin:18px 0 0 0; }

/* === FORM & INPUTS === */
input, textarea, select {
  border: 2px solid var(--secondary);
  border-radius:11px;
  padding:10px 15px;
  font-size:1rem;
  margin-bottom:15px;
  background:#FFF;
  color:var(--primary);
  transition:border .2s;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--art-pink);
}
label { font-weight:600; color:var(--art-blue); margin-bottom:4px; }

/* === TABLES === */
table { border-collapse:collapse; width:100%; margin:24px 0; }
th,td { padding:10px 7px; border:1.5px solid var(--art-yellow); text-align:left; font-size:1rem; }
th {background: var(--art-yellow); color: var(--art-purple); font-weight:700; }

/* === COOKIE CONSENT BANNER === */
.cookie-banner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  position: fixed;
  left: 0; right: 0;
  bottom: 0;
  z-index: 2000;
  padding: 22px 16px 18px 16px;
  background: var(--art-yellow);
  color: var(--primary);
  box-shadow: 0 -4px 22px 0 rgba(70,174,179,0.12);
  border-top-left-radius: 23px;
  border-top-right-radius: 23px;
  font-size: 1rem;
}
.cookie-banner p { margin:0 0 6px 0; }
.cookie-banner .cookie-actions { display:flex; gap:20px; margin-top:10px; flex-wrap:wrap; }
.cookie-banner button,.cookie-banner .button {
  padding:10px 22px; border-radius:18px; font-weight:700; border:none; box-shadow:0 1px 4px 0 rgba(70,174,179,0.07);
  transition:background .18s, color .16s; font-size:1rem; cursor:pointer;
}
.cookie-banner .accept { background:var(--art-pink); color:#fff; }
.cookie-banner .accept:hover{ background:var(--art-purple); }
.cookie-banner .reject { background:var(--danger); color:#fff; }
.cookie-banner .reject:hover { background:var(--art-yellow); color:var(--primary); }
.cookie-banner .settings { background:#fff; color:var(--primary); border:2px dashed var(--secondary); }
.cookie-banner .settings:hover { background:var(--art-blue); color:#fff; }

/* === COOKIE MODAL === */
.cookie-modal {
  position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:3000;
  background:rgba(63,77,64,0.87);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .25s;
}
.cookie-modal.open { opacity:1; pointer-events:all; }
.cookie-modal-content {
  background: #fffbd5;
  border-radius:27px;
  padding:36px 24px 24px 24px;
  box-shadow:0 6px 44px 0 rgba(231,111,118,0.19);
  min-width:320px; max-width:94vw;
  font-size:1.10rem;
  color: var(--primary);
  display:flex; flex-direction:column; align-items:flex-start; gap:19px;
  position:relative;
}
.cookie-modal-content h2 {
  color:var(--art-purple); margin:0 0 8px 0; font-size:1.18rem;
}
.cookie-modal-close {
  position:absolute; top:18px; right:22px; background:none; border:none; color:var(--primary); font-size:2rem; cursor:pointer;
}
.cookie-modal-categories { display:flex; flex-direction:column; gap:15px; }
.cookie-modal-toggle { display:flex; align-items:center; gap:8px;}
.cookie-modal-toggle input[type="checkbox"] {accent-color: var(--art-blue);width:20px;height:20px;}
.cookie-modal-actions {display:flex;gap:20px;margin-top:14px;}
.cookie-modal-actions button {padding:11px 28px;border-radius:18px;font-weight:700;border:none;font-size:1rem;cursor:pointer;transition:background .18s;
background:var(--secondary);color:#fff;}
.cookie-modal-actions button:hover {background:var(--art-pink); color:#fff;}

@media (max-width: 440px) {
  .cookie-modal-content { min-width:0; padding:18px 8px; }
  .cookie-banner { font-size:0.95em; padding:13px 6px 9px 6px; }
}

/* === ANIMATIONS & MICRO-INTERACTIONS === */
.button, .button.primary { transition: background .21s, box-shadow .2s, color .16s, transform .15s; }
.button:active, .button.primary:active { transform:scale(0.96); }
.feature-list li, .card, .testimonial-card { transition: transform .14s, box-shadow .24s; }
.feature-list li:active, .card:active, .testimonial-card:active { transform:scale(0.99) rotate(-1deg); }
.mobile-menu,
.mobile-menu.open { transition: transform .38s cubic-bezier(.77,0,.18,1); }
@media (prefers-reduced-motion: no-preference) {
  .section,.card,.testimonial-card { transition:box-shadow .22s, background .18s, transform .18s; }
}

/* === RESPONSIVE ADJUSTMENTS === */
@media (max-width: 1200px) { .container { max-width: 98vw; } }
@media (max-width: 900px) {
  .content-grid, .card-container, .feature-list { flex-direction:column; gap:18px; }
  .footer-grid { gap:22px; }
}
@media (max-width: 600px) {
  h1 { font-size:1.45rem; }
  h2 { font-size:1.12rem; }
  .feature-list,.feature-item,.content-wrapper { gap:10px;padding:0; }
}

/* === ACCESSIBILITY CONTRAST ENHANCEMENTS === */
.testimonial-card {
  background: #FFF;
  color: var(--primary);
  border: 1.5px solid var(--art-blue);
}
.testimonial-card p, .testimonial-card span {
  color: #3F4D40; /* dark text on light bg */
}

/* === UNIQUE ARTISTIC ACCENTS === */
.section::before {
  content: "";
  display: block;
  position: absolute;
  top: -32px;left: -22px;
  width: 55px; height: 55px;
  border-radius: 26% 44% 38% 63%/45% 26% 48% 29%;
  background: rgba(231,111,118,0.13);
  z-index: 0;
}
.section:nth-of-type(2)::before {
  left:unset;right: -22px; top:-42px;
  background: rgba(70,174,179,0.13);
  border-radius: 60% 25% 55% 45%/40% 44% 25% 65%;
  width:45px;height:45px;
}
@media (max-width:600px) {
  .section::before,.section:nth-of-type(2)::before {width:30px;height:30px;top:-18px;left:-10px;}
}

/* === MISC === */
a[aria-current="page"] { background: var(--art-yellow); color:var(--primary); font-weight:700; }
.logo {height:40px;max-width:140px;display:inline-block;}

/* === UTILITIES === */
.mt-32{margin-top:32px;}
.mb-32{margin-bottom:32px;}
.mt-20{margin-top:20px;}
.mb-20{margin-bottom:20px;}
.text-center{text-align:center;}

/* === END === */
