:root{
  --bg:#0f1720;
  --panel:#162130;
  --panel2:#1b2838;
  --line:rgba(255,255,255,.10);
  --text:#eef4f8;
  --muted:#9fb0bf;
  --soft:#c7d2dc;
  --accent:#b99768;
  --accent2:#6f8fa8;
  --danger:#e89191;
  --ok:#9bd5b0;
  --shadow:0 18px 60px rgba(0,0,0,.28);
  --radius:24px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:radial-gradient(circle at 20% 0%, #23354a 0, transparent 28%), linear-gradient(135deg,#0d141d,#101923 45%,#0b1017);
  color:var(--text);
  min-height:100vh;
}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
.app-shell{width:min(1480px, calc(100% - 32px)); margin:0 auto; padding:24px 0 36px}
.topbar{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:14px 16px; border:1px solid var(--line); border-radius:22px;
  background:rgba(15,23,32,.74); backdrop-filter:blur(20px); position:sticky; top:12px; z-index:10; box-shadow:var(--shadow);
}
.brand{display:flex; align-items:center; gap:12px}
.brand-mark{
  width:42px; height:42px; display:grid; place-items:center; border-radius:14px;
  background:linear-gradient(135deg,#d3b982,#7e613a); color:#111; font-weight:900; letter-spacing:.04em;
}
.brand strong{display:block; font-size:1.02rem}
.brand small{display:block; color:var(--muted); margin-top:2px}
.ghost-btn,.primary-btn,.cat-btn,.look-card{
  border:none; border-radius:14px; color:var(--text); transition:.18s ease; outline:none;
}
.ghost-btn{background:rgba(255,255,255,.06); border:1px solid var(--line); padding:10px 14px}
.ghost-btn:hover{background:rgba(255,255,255,.11)}
.primary-btn{
  width:100%; padding:15px 18px; margin-top:18px; color:#111; font-weight:850;
  background:linear-gradient(135deg,#e5c98d,#b89358); box-shadow:0 12px 30px rgba(185,147,84,.22);
}
.primary-btn:hover{transform:translateY(-1px); filter:brightness(1.04)}
main{margin-top:22px}
.hero-card{
  display:grid; grid-template-columns:1.4fr .6fr; gap:18px; border:1px solid var(--line); border-radius:var(--radius);
  padding:24px; background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.03)); box-shadow:var(--shadow);
}
.hero-card.compact{padding:20px}
.eyebrow{margin:0 0 8px; color:var(--accent); text-transform:uppercase; font-size:.75rem; letter-spacing:.14em; font-weight:800}
h1{font-size:clamp(2rem,4vw,4.2rem); line-height:.95; margin:0 0 12px; letter-spacing:-.06em}
h2{margin:0; letter-spacing:-.035em}
p{color:var(--soft); line-height:1.55}
.hero-copy p:last-child{max-width:760px; margin-bottom:0}
.hero-panel{
  border-radius:20px; padding:18px; border:1px solid var(--line); background:rgba(0,0,0,.18); display:flex; flex-direction:column; justify-content:center; gap:8px;
}
.hero-panel strong{font-size:1.25rem}
.hero-panel small{color:var(--muted); line-height:1.5}
.workspace{display:grid; grid-template-columns:minmax(330px,430px) 1fr; gap:18px; margin-top:18px; align-items:start}
.input-panel,.output-panel{
  border:1px solid var(--line); border-radius:var(--radius); background:rgba(22,33,48,.82); box-shadow:var(--shadow);
}
.input-panel{padding:18px; position:sticky; top:102px}
.output-panel{padding:18px; min-height:520px}
.step-head{display:flex; gap:12px; align-items:flex-start; margin:2px 0 12px}
.step-head span{
  flex:0 0 34px; width:34px; height:34px; display:grid; place-items:center; border-radius:12px;
  background:rgba(185,151,104,.15); color:var(--accent); font-weight:900; border:1px solid rgba(185,151,104,.22)
}
.step-head h2{font-size:1.15rem}
.step-head p{margin:2px 0 0; color:var(--muted); font-size:.93rem}
.mt{margin-top:22px}.tight{margin-bottom:8px}
.dropzone{
  display:grid; place-items:center; text-align:center; gap:8px; padding:26px 16px; min-height:150px;
  border:1.5px dashed rgba(255,255,255,.18); border-radius:20px; background:rgba(255,255,255,.035); cursor:pointer;
}
.dropzone.dragover{border-color:var(--accent); background:rgba(185,151,104,.12)}
.dropzone input{display:none}
.upload-icon{font-size:2rem; color:var(--accent)}
.dropzone small{color:var(--muted)}
.file-status{margin-top:10px; padding:10px 12px; border-radius:14px; color:var(--ok); background:rgba(155,213,176,.10); border:1px solid rgba(155,213,176,.20); font-size:.9rem}
.file-status.error{color:var(--danger); background:rgba(232,145,145,.10); border-color:rgba(232,145,145,.20)}
.category-row{display:flex; gap:8px; flex-wrap:wrap}
.cat-btn{padding:10px 12px; background:rgba(255,255,255,.06); border:1px solid var(--line); color:var(--soft); font-weight:750}
.cat-btn.active{background:rgba(185,151,104,.20); border-color:rgba(185,151,104,.45); color:#fff}
.look-cards{display:grid; grid-template-columns:1fr; gap:10px; max-height:360px; overflow:auto; padding-right:4px}
.look-card{
  display:block; width:100%; text-align:left; padding:13px 14px; background:rgba(255,255,255,.055); border:1px solid var(--line);
}
.look-card:hover{background:rgba(255,255,255,.09)}
.look-card.active{border-color:rgba(185,151,104,.65); box-shadow:0 0 0 3px rgba(185,151,104,.12); background:rgba(185,151,104,.13)}
.look-card strong{display:block; font-size:.98rem; margin-bottom:3px}
.look-card span{display:block; color:var(--soft); font-size:.88rem; margin-bottom:5px}
.look-card small{display:block; color:var(--accent); font-weight:750; font-size:.78rem}
.optional-box{margin-top:16px; border:1px solid var(--line); border-radius:18px; padding:12px 14px; background:rgba(255,255,255,.035)}
.optional-box summary{cursor:pointer; color:var(--soft); font-weight:800}
.optional-box label{display:block; margin-top:12px}
.optional-box label span,.notes-field span{display:block; margin-bottom:7px; color:var(--muted); font-size:.86rem; font-weight:800}
select,textarea{
  width:100%; border:none; border-radius:14px; background:#0d151f; color:var(--text); padding:12px 13px; border:1px solid var(--line)
}
textarea{resize:vertical; min-height:82px}
.preview-card,.result,.empty-state{
  border:1px solid var(--line); border-radius:22px; padding:18px; background:rgba(255,255,255,.04)
}
.preview-head,.result-head{display:flex; justify-content:space-between; gap:16px; align-items:flex-start; margin-bottom:14px}
.preview-head p{margin:4px 0 0; color:var(--muted)}
.look-pill{padding:8px 10px; border-radius:999px; background:rgba(185,151,104,.16); color:var(--accent); border:1px solid rgba(185,151,104,.25); font-size:.78rem; font-weight:900; white-space:nowrap}
.preview-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.preview-figure{margin:0}.preview-figure>span{display:block; margin-bottom:8px; color:var(--muted); font-size:.84rem; font-weight:900}
.preview-frame{
  position:relative; aspect-ratio:3/4; border-radius:18px; overflow:hidden; background:#0b1118; border:1px solid var(--line); display:grid; place-items:center;
}
.preview-frame img{width:100%; height:100%; object-fit:cover; display:none; transition:filter .2s ease, opacity .2s ease}
.preview-placeholder{position:absolute; inset:0; display:grid; place-items:center; text-align:center; padding:20px; color:var(--muted); font-size:.92rem}
.preview-note,.raw-preview p{margin:12px 0 0; color:var(--muted); font-size:.92rem}.raw-preview{padding:14px; border-radius:16px; background:rgba(185,151,104,.11); border:1px solid rgba(185,151,104,.22)}
.empty-state{margin-top:18px; text-align:center; padding:42px 20px}.lens-icon{font-size:2rem; color:var(--accent)}.empty-state p{margin-bottom:0;color:var(--muted)}
.result{margin-top:18px}.result-head h2{font-size:1.8rem}.result-head p{margin:4px 0 0; color:var(--muted)}.actions{display:flex; gap:8px; flex-wrap:wrap}
.summary-grid{display:grid; grid-template-columns:repeat(5, minmax(0,1fr)); gap:10px; margin:14px 0}
.summary-card{padding:12px; border-radius:16px; background:rgba(0,0,0,.15); border:1px solid var(--line); min-width:0}.summary-card small{display:block; color:var(--muted); margin-bottom:4px}.summary-card strong{font-size:.86rem; overflow-wrap:anywhere}
.tabs{display:flex; gap:8px; flex-wrap:wrap; border-bottom:1px solid var(--line); padding-bottom:10px; margin:14px 0}.tab{border:none; border-radius:999px; padding:9px 13px; background:rgba(255,255,255,.06); color:var(--soft); font-weight:850}.tab.active{background:rgba(185,151,104,.20); color:#fff}
.tab-panel{display:none}.tab-panel.active{display:block}
.recipe-section{margin-top:14px; border:1px solid var(--line); border-radius:18px; padding:14px 16px; background:rgba(255,255,255,.035)}
.recipe-section.warning{border-color:rgba(185,151,104,.28); background:rgba(185,151,104,.08)}.recipe-section h3{margin:0 0 10px; font-size:1rem;color:#fff}.recipe-section ol,.recipe-section ul{margin:0; padding-left:20px}.recipe-section li{margin:8px 0; line-height:1.5; color:var(--soft)}code{padding:2px 6px; border-radius:8px; background:rgba(0,0,0,.25); color:#f0d59b}
footer{display:flex; justify-content:space-between; gap:12px; margin-top:18px; color:var(--muted); font-size:.88rem; padding:0 6px}
@media (max-width:1050px){.hero-card,.workspace{grid-template-columns:1fr}.input-panel{position:relative; top:auto}.summary-grid{grid-template-columns:1fr 1fr}.preview-grid{grid-template-columns:1fr 1fr}}
@media (max-width:700px){.app-shell{width:min(100% - 18px, 1480px); padding-top:10px}.topbar{top:6px}.brand small{display:none}.hero-card{padding:16px}.preview-grid{grid-template-columns:1fr}.summary-grid{grid-template-columns:1fr}.preview-head,.result-head{flex-direction:column}.look-pill{white-space:normal}footer{flex-direction:column}.output-panel,.input-panel{padding:12px}}
@media print{body{background:white;color:#111}.topbar,.hero-card,.input-panel,.preview-card,.empty-state,.tabs,footer,.actions{display:none!important}.app-shell{width:100%;padding:0}.workspace{display:block}.output-panel,.result,.recipe-section{border:0;box-shadow:none;background:white;color:#111}.tab-panel{display:block!important}.recipe-section li,p{color:#111}}
