/* static/style.css
   Glassmorphism skin for Recipe Manager (mockup B direction).
   Loaded AFTER bootstrap.min.css in base.html so these rules win on the
   elements they target. Bootstrap component CSS (.modal, .form-control,
   .form-select, .nav-tabs, .list-group, .btn-close, .alert) is left alone
   on purpose -- the item/ingredient "Add" modals still use it.
*/

:root{
  --accent:#e08a52;
  --accent-2:#f0a76e;
  --text:#fff;
  --muted:rgba(255,255,255,.68);
  --green:#6fd29a;
  --amber:#f0c869;
  --red:#f08a7d;
  --sidebar-w:240px;
}

*{box-sizing:border-box;}

html,body{margin:0;min-height:100%;}

body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:url('img/bg.jpg') center/cover no-repeat fixed;
  min-height:100vh;
}

a{ color:inherit; }

/* glass utility */
.glass{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-radius:18px;
}

/* ---------- Layout ---------- */
.app-layout{
  display:flex;
  min-height:100vh;
  padding:18px;
  gap:18px;
}

/* ---------- Sidebar ---------- */
.sidebar{
  width:var(--sidebar-w);
  flex:0 0 auto;
  display:flex;
  flex-direction:column;
  padding:22px 16px;
}
.brand{
  display:flex;align-items:center;gap:10px;
  padding:4px 8px 22px;
  border-bottom:1px solid rgba(255,255,255,.16);
  margin-bottom:14px;
}
.brand-mark{
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:16px;color:#241a12;
  flex:0 0 auto;
}
.brand-name{font-size:16px;font-weight:650;}
.brand-sub{font-size:11px;color:var(--muted);}

nav.nav-links{flex:1;display:flex;flex-direction:column;}
.nav-item{
  display:flex;align-items:center;gap:11px;
  padding:11px 14px;margin-bottom:5px;
  border-radius:11px;
  font-size:14px;font-weight:550;
  color:rgba(255,255,255,.82);
  text-decoration:none;
  transition:background .15s ease;
}
.nav-item svg{width:17px;height:17px;opacity:.85;flex:0 0 auto;}
.nav-item:hover{background:rgba(255,255,255,.10);color:#fff;}
.nav-item.active{
  background:rgba(255,255,255,.20);
  color:#fff;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.25);
}

.sidebar-footer{
  padding-top:14px;border-top:1px solid rgba(255,255,255,.16);
}
.user-chip{display:flex;align-items:center;gap:10px;font-size:13px;padding:6px 8px;}
.user-avatar{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#241a12;
  flex:0 0 auto;
}
.user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.logout-link{font-size:12px;color:var(--muted);margin-left:auto;text-decoration:none;}
.logout-link:hover{color:#fff;}

.menu-toggle{
  display:none;
  margin-left:auto;
  align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.14);
  border:none;color:#fff;cursor:pointer;
}

/* ---------- Main ---------- */
.main{flex:1;min-width:0;display:flex;flex-direction:column;gap:18px;}
.content-wrap{flex:1;display:flex;flex-direction:column;gap:18px;}

.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;
}
.topbar h1{font-size:22px;margin:0;font-weight:650;}
.topbar .meta{font-size:12.5px;color:var(--muted);margin-top:3px;}

.btn-glass{border:none;border-radius:10px;padding:9px 16px;font-size:13.5px;font-weight:650;cursor:pointer;}
.btn-glass-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#241a12;}
.btn-glass-primary:hover{opacity:.92;}

/* ---------- Stat cards (dashboard) ---------- */
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:0 22px;}
.stat-card{padding:18px 20px;}
.stat-label{font-size:12.5px;color:var(--muted);font-weight:600;}
.stat-value{font-size:32px;font-weight:700;margin:6px 0 6px;}
.stat-link{font-size:12.5px;font-weight:650;color:var(--accent-2);text-decoration:none;}
.stat-link:hover{color:var(--accent);}

/* ---------- Panel / table ---------- */
.panel{overflow:hidden;margin:0 22px 22px;}
.panel-head{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:10px;
  padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.14);
}
.panel-head h1, .panel-head h2{font-size:16px;margin:0;font-weight:650;}

.filter-input{
  border:1px solid rgba(255,255,255,.25);border-radius:9px;padding:7px 12px;font-size:13px;
  background:rgba(255,255,255,.08);color:#fff;width:230px;
}
.filter-input::placeholder{color:rgba(255,255,255,.55);}
.filter-input:focus{outline:none;border-color:var(--accent-2);background:rgba(255,255,255,.14);}

.panel table{width:100%;border-collapse:collapse;font-size:13.5px;}
.panel th{
  text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.06em;
  color:var(--muted);font-weight:650;padding:10px 20px;border-bottom:1px solid rgba(255,255,255,.14);
  white-space:nowrap;
}
.panel td{padding:12px 20px;border-bottom:1px solid rgba(255,255,255,.10);vertical-align:middle;}
.panel tr:last-child td{border-bottom:none;}
.panel tbody tr:hover td{background:rgba(255,255,255,.05);}

.name-link{color:var(--accent-2);font-weight:650;text-decoration:none;}
.name-link:hover{color:var(--accent);}
.row-actions a, .row-actions button{
  font-size:12px;color:var(--muted);margin-right:12px;font-weight:600;
  background:none;border:none;cursor:pointer;padding:0;text-decoration:none;
}
.row-actions a:hover, .row-actions button:hover{color:#fff;}
.row-actions button.text-danger-link:hover{color:var(--red);}

.text-success{color:var(--green) !important;}
.text-warning{color:var(--amber) !important;}
.text-danger{color:var(--red) !important;}

/* flash messages over the glass background */
.content-wrap .alert{border-radius:12px;border:none;margin:0 22px 18px;}

/* import page key/legend sits inside .content-wrap too */
.content-wrap .key-grid{margin:0 22px;}
.content-wrap .drop-zone-wrap{margin:0 22px;}

/* ---------- Inline-editable ingredient fields ---------- */
.ing-field{
  width:100%;
  background:transparent;
  border:1px solid transparent;
  border-radius:7px;
  padding:6px 8px;
  font-size:13.5px;
  color:#fff;
  font-family:inherit;
}
.ing-field:hover{border-color:rgba(255,255,255,.18);}
.ing-field:focus{
  outline:none;
  border-color:var(--accent-2);
  background:rgba(255,255,255,.10);
}
.ing-field.ing-cost{width:110px;}
.ing-field.ing-unit{width:90px;}
td.ing-cell{padding:6px 10px;}

tr.row-saved td{ transition: background-color .25s ease; background-color: rgba(111,210,154,.14); }
tr.row-error td{ transition: background-color .25s ease; background-color: rgba(240,138,125,.16); }
.row-msg{font-size:11.5px;color:var(--muted);margin-left:6px;}
tr.row-error .row-msg{color:var(--red);}
tr.row-saved .row-msg{color:var(--green);}

/* ---------- Import page key/legend ---------- */
.key-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(260px,1fr));gap:16px;}
.key-card{padding:16px 18px;}
.key-card h3{font-size:14px;margin:0 0 4px;font-weight:650;}
.key-card .key-note{font-size:12px;color:var(--muted);margin-bottom:10px;}
.key-card table{width:100%;border-collapse:collapse;font-size:12.5px;}
.key-card th{
  text-align:left;color:var(--muted);font-weight:650;
  padding:5px 0;border-bottom:1px solid rgba(255,255,255,.14);
  text-transform:uppercase;font-size:10.5px;letter-spacing:.05em;
}
.key-card td{padding:6px 0;border-bottom:1px solid rgba(255,255,255,.08);vertical-align:top;}
.key-card tr:last-child td{border-bottom:none;}
.key-card code{background:rgba(255,255,255,.12);padding:1px 5px;border-radius:5px;font-size:12px;}
.key-required{color:var(--accent-2);font-weight:650;}
.key-card.key-unused{opacity:.7;}

/* ---------- Drop zone (import) ---------- */
.drop-zone{
  border:2px dashed rgba(255,255,255,.3);
  border-radius:16px;
  padding:48px 24px;
  text-align:center;
  cursor:pointer;
  transition:background .15s ease, border-color .15s ease;
}
.drop-zone:hover, .drop-zone.drag-over{
  background:rgba(255,255,255,.08);
  border-color:var(--accent-2);
}
.drop-zone p{margin:0 0 4px;color:var(--muted);}
.drop-zone code{background:rgba(255,255,255,.12);padding:1px 6px;border-radius:5px;}

/* ---------- Login page ---------- */
.login-page{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:#fff;
  background:url('img/bg.jpg') center/cover no-repeat fixed;
}
.login-card{
  width:100%;max-width:380px;
  padding:34px 30px;
  margin:20px;
}
.login-card .brand-mark{margin:0 auto 14px;}
.login-card h1{font-size:20px;text-align:center;margin:0 0 22px;font-weight:650;}
.login-card .form-label{color:rgba(255,255,255,.82);font-size:13px;}
.login-card .form-control{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.22);
  color:#fff;
}
.login-card .form-control:focus{
  background:rgba(255,255,255,.14);
  border-color:var(--accent-2);
  color:#fff;
  box-shadow:none;
}
.login-card .form-control::placeholder{color:rgba(255,255,255,.45);}
.login-card .btn-glass-primary{width:100%;padding:11px;font-size:14px;}

/* ---------- Footer ---------- */
.app-footer{
  text-align:center;
  color:var(--muted);
  font-size:12px;
  padding:10px 0 4px;
}

/* ---------- Mobile ---------- */
@media (max-width: 860px){
  body{background-attachment:scroll;}
  .login-page{background-attachment:scroll;}

  .app-layout{padding:0;gap:0;flex-direction:column;}
  .sidebar{
    width:100%;flex-direction:row;align-items:center;
    border-radius:0;padding:12px 14px;position:relative;
  }
  .brand{border-bottom:none;padding:0;margin-bottom:0;flex:1;}
  nav.nav-links{
    display:none;
    position:absolute;top:100%;left:14px;right:14px;margin-top:8px;
    background:rgba(20,16,12,.85);
    backdrop-filter:blur(18px) saturate(140%);
    -webkit-backdrop-filter:blur(18px) saturate(140%);
    border:1px solid rgba(255,255,255,.18);
    border-radius:14px;
    padding:10px;
    z-index:200;
  }
  nav.nav-links.nav-open{display:flex;}
  .sidebar-footer{display:none;}
  .menu-toggle{display:flex;}

  .main{gap:14px;}
  .topbar{padding:16px 16px 0;flex-direction:column;align-items:flex-start;gap:10px;}
  .stat-grid{grid-template-columns:1fr;padding:0 16px;}
  .panel{margin:0 16px 16px;}
  .content-wrap .alert{margin:0 16px 16px;}
  .content-wrap .key-grid{margin:0 16px;}
  .content-wrap .drop-zone-wrap{margin:0 16px;}
  .filter-input{width:100%;}
  .panel-head{flex-direction:column;align-items:flex-start;gap:10px;}
  .panel th:nth-child(2), .panel td:nth-child(2){display:none;}
  .key-grid{grid-template-columns:1fr;}
}
