@import url("fonts/clash-display.css");
@import url("https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,300&display=swap");

/* ══════════════════════════════════════════════════════════════
   étuCook — Design System v2
   Direction : Magazine culinaire — éditorial, chaleureux, moderne
   Typographie : Playfair Display (titres) + DM Sans (corps)
   Palette imposée : crème · caramel · forêt
══════════════════════════════════════════════════════════════ */
:root {
  --bg:          #faf9f2;
  --surface:     #ffffff;
  --sand:        #edeade;
  --sand-2:      #f0ede0;
  --caramel:     #d9a97e;
  --caramel-d:   #c08a5e;
  --caramel-l:   #efd4b8;
  --forest:      #1b4a36;
  --forest-m:    #2d6147;
  --forest-l:    #4a8c68;
  --forest-pale: rgba(27,74,54,.08);
  --ink:         #1a1a14;
  --ink-2:       #3d3d30;
  --muted:       #8a8a7a;
  --muted-l:     #b8b8a8;
  --white:       #fff;
  --danger:      #c0392b;
  --danger-bg:   rgba(192,57,43,.07);
  --nav-h: 70px;
  --nav-top: 14px;
  --r-pill: 999px;
  --r-2xl: 28px; --r-xl: 20px; --r-lg: 16px; --r-md: 12px; --r-sm: 8px; --r-xs: 5px;
  --sh-nav:  0 4px 28px rgba(26,26,20,.10);
  --sh-card: 0 2px 16px rgba(26,26,20,.07);
  --sh-lift: 0 12px 40px rgba(26,26,20,.14);
  --sh-btn:  0 4px 16px rgba(27,74,54,.22);
  --t: .22s cubic-bezier(.4,0,.2,1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'DM Sans', ClashDisplay-Regular, sans-serif;
  background: var(--bg); color: var(--ink); min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  background-image:
    radial-gradient(ellipse 80% 50% at 5% 0%,   rgba(217,169,126,.13) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 95% 100%, rgba(27,74,54,.07)   0%, transparent 60%);
}
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-thumb { background: var(--caramel-l); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: var(--caramel); }

/* ════ NAVBAR ════ */
.navbar {
  position: fixed; top: var(--nav-top); left: 50%; transform: translateX(-50%);
  z-index: 900; width: min(1080px, 97vw); height: var(--nav-h);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 12px 0 6px;
  background: rgba(250,249,242,.92); backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255,255,255,.9); border-radius: var(--r-pill); box-shadow: var(--sh-nav);
}
.navbar__logo { all: unset; cursor: pointer; display: flex; align-items: center; transition: opacity var(--t); }
.navbar__logo:hover { opacity: .85; }
.navbar__logo img { height: 8em; margin-top: 4px; }
.navbar__links { display: flex; align-items: center; gap: 2px; position: relative; }

.nav-btn {
  background: none; border: none; color: var(--ink-2);
  font-family: 'DM Sans', sans-serif; font-size: 13.5px; font-weight: 500;
  padding: 8px 13px; border-radius: var(--r-pill); cursor: pointer;
  transition: background var(--t), color var(--t); white-space: nowrap;
}
.nav-btn:hover { background: var(--forest-pale); color: var(--forest); }
.nav-btn--icon { width: 38px; height: 38px; padding: 0; display: flex; align-items: center; justify-content: center; border-radius: 50%; }
.nav-btn--icon svg { width: 17px; height: 17px; stroke: var(--ink-2); stroke-width: 2; fill: none; transition: stroke var(--t); }
.nav-btn--icon:hover svg { stroke: var(--forest); }
.nav-btn--profile {
  background: var(--forest); color: var(--white);
  font-weight: 600; letter-spacing: .3px; padding: 9px 20px; margin-left: 4px;
}
.nav-btn--profile:hover { background: var(--forest-m); box-shadow: var(--sh-btn); }

/* Dropdown */
.nav-dropdown {
  display: none; flex-direction: column; gap: 6px;
  position: absolute; right: 0; top: calc(100% + 10px); min-width: 210px;
  background: var(--surface); border: 1px solid rgba(0,0,0,.08);
  border-radius: var(--r-lg); padding: 10px;
  box-shadow: var(--sh-lift); z-index: 1000; animation: fadeDown .16s ease;
}
.nav-dropdown.open { display: flex; }
.nav-dropdown__user { display: flex; align-items: center; gap: 10px; padding: 9px 10px; background: var(--sand); border-radius: var(--r-sm); }
.nav-dropdown__user img { width: 30px; height: 30px; border-radius: 50%; }
.nav-dropdown__user-name { font-weight: 700; font-size: 13px; color: var(--ink); }
.nav-dropdown__user-label { font-size: 11px; color: var(--muted); }
.nav-dropdown__sep { border: none; border-top: 1px solid rgba(0,0,0,.07); }
.nav-dropdown__item {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 12px; font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 600;
  border-radius: var(--r-sm); text-decoration: none; cursor: pointer;
  transition: all var(--t); border: none; background: none; width: 100%; text-align: left;
}
.nav-dropdown__item--danger { color: var(--danger); background: var(--danger-bg); border: 1px solid rgba(192,57,43,.15); }
.nav-dropdown__item--danger:hover { background: var(--danger); color: var(--white); border-color: var(--danger); }
.nav-dropdown__item--plain { color: var(--forest); background: var(--forest-pale); border: 1px solid rgba(27,74,54,.12); }
.nav-dropdown__item--plain:hover { background: var(--forest); color: var(--white); }
.nav-dropdown__item svg { width: 14px; height: 14px; flex-shrink: 0; }

@keyframes fadeDown { from { opacity:0; transform: translateY(-8px) scale(.97); } to { opacity:1; transform: translateY(0) scale(1); } }

/* ════ BUTTONS universels ════ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  cursor: pointer; border: none; text-decoration: none;
  font-family: 'DM Sans', sans-serif; font-weight: 600; letter-spacing: .1px;
  transition: all var(--t); white-space: nowrap;
}
.btn--lg { padding: 14px 32px; font-size: 14.5px; border-radius: var(--r-pill); }
.btn--md { padding: 11px 22px; font-size: 13.5px; border-radius: var(--r-pill); }
.btn--sm { padding: 7px 15px; font-size: 12.5px; border-radius: var(--r-pill); }
.btn--xs { padding: 5px 11px; font-size: 11.5px; border-radius: var(--r-pill); }
.btn--forest { background: var(--forest); color: var(--white); border: 2px solid var(--forest-m); box-shadow: var(--sh-btn); }
.btn--forest:hover { background: var(--forest-m); transform: translateY(-2px); }
.btn--ghost { background: var(--forest-pale); color: var(--forest); border: 1.5px solid rgba(27,74,54,.2); }
.btn--ghost:hover { background: var(--forest); color: var(--white); transform: translateY(-1px); }
.btn--caramel { background: var(--caramel); color: var(--white); border: 2px solid var(--caramel-d); }
.btn--caramel:hover { background: var(--caramel-d); transform: translateY(-1px); }
.btn--danger { background: var(--danger-bg); color: var(--danger); border: 1.5px solid rgba(192,57,43,.2); }
.btn--danger:hover { background: var(--danger); color: var(--white); }
.btn--outline { background: transparent; color: var(--muted); border: 1.5px solid rgba(0,0,0,.14); }
.btn--outline:hover { border-color: var(--ink-2); color: var(--ink); }

/* ════ HERO (index) ════ */
.hero { display: grid; place-items: center; min-height: 100vh; padding: 0 20px; }
.hero__inner { display: flex; flex-direction: column; align-items: center; gap: 26px; max-width: 700px; text-align: center; animation: fadeUp .8s ease both; }
@keyframes fadeUp { from { opacity:0; transform: translateY(30px); } to { opacity:1; transform: translateY(0); } }
.hero__eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 18px; font-size: 11px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase;
  color: var(--forest); background: rgba(27,74,54,.08); border: 1px solid rgba(27,74,54,.16); border-radius: var(--r-pill);
}
.hero__dot { width: 6px; height: 6px; background: var(--caramel); border-radius: 50%; animation: blink 2s infinite; }
@keyframes blink { 0%,100% { opacity:1; } 50% { opacity:.3; } }
.hero__title {
  font-family: 'Playfair Display', serif; font-size: clamp(3.2rem, 7vw, 5.2rem);
  font-weight: 700; line-height: 1.05; letter-spacing: -2px; color: var(--ink);
}
.hero__title em { font-style: italic; color: var(--forest); }
.hero__title strong {
  display: inline-block; position: relative;
  background: linear-gradient(135deg, var(--caramel) 0%, var(--caramel-d) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.hero__sub { font-size: 17px; color: var(--muted); line-height: 1.7; max-width: 440px; }
.hero__cta { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; animation: fadeUp .8s .2s ease both; }

/* ════ AUTH ════ */
.auth-wrap { display: flex; align-items: center; justify-content: center; min-height: 100vh; padding: calc(var(--nav-h) + var(--nav-top) + 28px) 20px 48px; }
.auth-card { width: 100%; max-width: 470px; background: var(--surface); border-radius: var(--r-2xl); border: 1px solid rgba(0,0,0,.06); padding: 50px 46px 44px; box-shadow: var(--sh-lift); animation: fadeDown .3s ease; }
.auth-card__eyebrow { font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); margin-bottom: 8px; }
.auth-card__title { font-family: 'Playfair Display', serif; font-size: 2.3rem; font-weight: 700; letter-spacing: -.5px; color: var(--ink); margin-bottom: 34px; }
.auth-alert { background: var(--danger-bg); border: 1px solid rgba(192,57,43,.2); border-radius: var(--r-sm); padding: 12px 16px; margin-bottom: 22px; font-size: 13px; color: var(--danger); line-height: 1.5; }
.auth-alert p { margin: 2px 0; }
.auth-switch { text-align: center; font-size: 13px; color: var(--muted); margin-top: 26px; }
.auth-switch a { color: var(--forest); font-weight: 600; text-decoration: none; border-bottom: 1.5px solid rgba(27,74,54,.25); transition: border-color var(--t); }
.auth-switch a:hover { border-color: var(--forest); }

/* ════ FORM FIELDS ════ */
.field { display: flex; flex-direction: column; gap: 5px; margin-bottom: 16px; }
.field--row { flex-direction: row; gap: 12px; }
.field--row > .field { flex: 1; min-width: 0; margin-bottom: 0; }
.field--center { align-items: center; }
.field__label { font-size: 11px; font-weight: 700; letter-spacing: .9px; text-transform: uppercase; color: var(--muted); }
.field__hint { font-size: 11px; color: var(--muted-l); font-weight: 400; text-transform: none; letter-spacing: 0; }
.field__error { display: none; font-size: 11.5px; color: var(--danger); margin-top: 2px; }

input[type="text"], input[type="number"], input[type="password"] {
  padding: 11px 14px; font-family: 'DM Sans', sans-serif; font-size: 14px; color: var(--ink);
  background: var(--sand); border: 1.5px solid rgba(0,0,0,.09); border-radius: var(--r-md);
  outline: none; width: 100%; transition: border-color var(--t), background var(--t), box-shadow var(--t);
}
input::placeholder { color: var(--muted-l); }
input[type="text"]:hover, input[type="number"]:hover, input[type="password"]:hover { border-color: rgba(27,74,54,.3); }
input[type="text"]:focus, input[type="number"]:focus, input[type="password"]:focus { border-color: var(--forest); background: var(--white); box-shadow: 0 0 0 3px rgba(27,74,54,.09); }

select {
  padding: 11px 34px 11px 14px; font-family: 'DM Sans', sans-serif; font-size: 14px; color: var(--ink);
  background: var(--sand); border: 1.5px solid rgba(0,0,0,.09); border-radius: var(--r-md);
  outline: none; width: 100%; cursor: pointer; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a8a7a' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center;
  transition: border-color var(--t), box-shadow var(--t);
}
select:focus { border-color: var(--forest); box-shadow: 0 0 0 3px rgba(27,74,54,.09); outline: none; }

textarea.textarea {
  padding: 11px 14px; font-family: 'DM Sans', sans-serif; font-size: 14px; color: var(--ink);
  background: var(--sand); border: 1.5px solid rgba(0,0,0,.09); border-radius: var(--r-md);
  outline: none; width: 100%; resize: vertical; min-height: 88px; line-height: 1.6;
  transition: border-color var(--t), background var(--t), box-shadow var(--t);
}
textarea.textarea::placeholder { color: var(--muted-l); }
textarea.textarea:focus { border-color: var(--forest); background: var(--white); box-shadow: 0 0 0 3px rgba(27,74,54,.09); }

/* Dropdown checkbox */
.select-container { position: relative; }
.select-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 11px 14px; font-family: 'DM Sans', sans-serif; font-size: 14px; color: var(--ink);
  background: var(--sand); border: 1.5px solid rgba(0,0,0,.09); border-radius: var(--r-md);
  cursor: pointer; user-select: none; transition: border-color var(--t);
}
.select-header:hover { border-color: rgba(27,74,54,.3); }
.arrow { font-size: 9px; color: var(--muted); transition: transform .2s; }
.arrow.open { transform: rotate(180deg); }
.select-dropdown {
  display: none; position: absolute; top: calc(100% + 5px); left: 0; right: 0;
  background: var(--surface); border: 1.5px solid rgba(0,0,0,.08); border-radius: var(--r-md);
  box-shadow: var(--sh-lift); padding: 5px; z-index: 600; max-height: 180px; overflow-y: auto;
}
.select-dropdown label {
  display: flex !important; align-items: center; gap: 9px; padding: 8px 10px;
  font-size: 13px; font-family: 'DM Sans', sans-serif; color: var(--ink);
  text-transform: none; letter-spacing: 0; font-weight: 400;
  border-radius: var(--r-xs); cursor: pointer; transition: background var(--t); margin: 0;
}
.select-dropdown label:hover { background: var(--forest-pale); }
.select-dropdown input[type="checkbox"] { accent-color: var(--forest); width: 14px; height: 14px; margin: 0; }

/* File input */
.file-btn { display: inline-flex; align-items: center; gap: 6px; padding: 9px 16px; font-family: 'DM Sans', sans-serif; font-size: 12.5px; font-weight: 600; color: var(--forest); background: var(--forest-pale); border: 1.5px solid rgba(27,74,54,.2); border-radius: var(--r-pill); cursor: pointer; transition: all var(--t); }
.file-btn:hover { background: var(--forest); color: var(--white); }
.file-name { font-size: 11.5px; color: var(--muted); font-style: italic; margin-top: 3px; }

@media (max-width: 640px) {
  .navbar { top: 8px; height: 58px; width: 97vw; padding: 0 8px 0 4px; }
  .auth-card { padding: 36px 22px 30px; }
  .auth-card__title { font-size: 1.9rem; }
  .field--row { flex-direction: column; }
  .hero__title { letter-spacing: -1px; }
}