@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=Inter:wght@400;500;600;700&family=Parisienne&display=swap');
*{box-sizing:border-box} body{margin:0;background:#fffdfb;color:#222;font-family:Inter,system-ui,sans-serif}
.topbar{height:82px;display:flex;align-items:center;justify-content:space-between;padding:0 34px;background:#fff;border-bottom:1px solid #e8e0da;position:sticky;top:0;z-index:10}
.brand{display:flex;gap:12px;align-items:center}.leaf{font-size:30px;color:#526b48}.brandName{font-family:Parisienne,cursive;font-size:42px;color:#1d2b1c}.brandSub{text-transform:uppercase;letter-spacing:2px;font-size:11px;color:#667}
nav{display:flex;gap:24px;align-items:center}nav a{text-decoration:none;color:#222;text-transform:uppercase;font-size:13px;letter-spacing:1px}
#installBtn,.primary{border:0;background:#526b48;color:white;border-radius:8px;padding:13px 18px;font-weight:700}
.appShell{display:grid;grid-template-columns:390px 1fr 390px;gap:0;min-height:calc(100vh - 82px)}
.sidebar{border-right:1px solid #e8e0da;background:#fff;padding:18px;overflow:auto}.sidebar.right{border-left:1px solid #e8e0da;border-right:0}
.card{background:#fff;border:1px solid #e8e0da;border-radius:14px;padding:16px;margin-bottom:16px;box-shadow:0 8px 28px rgba(60,40,20,.04)}
h2{font-family:Cormorant Garamond,serif;text-transform:uppercase;letter-spacing:1.5px;font-size:21px;margin:0 0 8px;color:#293526}
h2 span{display:inline-grid;place-items:center;width:28px;height:28px;background:#526b48;color:#fff;border-radius:50%;font-family:Inter;font-size:13px;margin-right:8px}
.help{margin:0 0 12px;color:#666;font-size:13px;line-height:1.4}.personRow{display:grid;grid-template-columns:1fr 112px 38px 26px;gap:7px;align-items:center;border-bottom:1px solid #f1ebe7;padding:7px 0}
input,select{width:100%;border:1px solid #ded6d1;border-radius:7px;padding:10px;background:white;font-size:14px}.thumb{width:36px;height:42px;object-fit:contain}.remove{border:0;background:transparent;color:#7a5d50;font-size:22px}
.outline{border:1px solid #526b48;background:white;color:#526b48;border-radius:8px;padding:12px 15px;font-weight:700}#addPerson{width:100%;margin-top:12px}
label{display:block;text-transform:uppercase;font-size:12px;font-weight:700;letter-spacing:1px;color:#5d5852;margin:13px 0 6px}
.toggles{display:grid;gap:8px}.toggle{display:grid;grid-template-columns:34px 1fr auto;gap:8px;align-items:center;border:1px solid #eee3de;border-radius:10px;padding:8px}.toggle img{height:34px;object-fit:contain}.toggle input{width:auto}
.stage{background:linear-gradient(180deg,#fff,#fffaf6);padding:22px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}.stageTop{width:min(100%,760px);display:flex;gap:12px;margin-bottom:14px}.stageTop button{border:0;background:#fff;border:1px solid #e5ddd7;border-radius:8px;padding:10px 13px}
#artboard{width:min(100%,760px);aspect-ratio:4/5;background:#fff;border:1px solid #e7ddd6;border-radius:18px;box-shadow:0 18px 55px rgba(60,40,30,.14);overflow:hidden}#svgArt{width:100%;height:100%;display:block}.zoomBar{margin-top:12px;background:#fff;border:1px solid #e5ddd7;border-radius:99px;padding:9px 22px;color:#666;box-shadow:0 10px 30px rgba(0,0,0,.06)}
.styleGrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.style{border:1px solid #e3dad4;border-radius:10px;background:#fff;padding:20px 8px;font-weight:700;color:#444}.style.active{border:2px solid #526b48;color:#526b48}
.swatches{display:flex;gap:14px}.swatches button{width:38px;height:38px;border-radius:50%;border:1px solid #ddd}.swatches button.active{outline:3px solid #cad3c1}
.bgGrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.bg{border:1px solid #e3dad4;background:#fff;border-radius:8px;padding:12px}.bg.active{border:2px solid #526b48;color:#526b48}.downloadCard{display:grid;gap:10px}.downloadCard button{width:100%}
.guide{max-width:1440px;margin:auto;padding:28px;text-align:center}.guide h2{font-size:28px}
#guideGrid{display:grid;grid-template-columns:repeat(6,1fr);border:1px solid #e8e0da;border-radius:14px;overflow:hidden;background:#fff}
.guideItem{padding:14px;border-right:1px solid #e8e0da;border-bottom:1px solid #e8e0da}.guideItem img{height:70px;max-width:100%;object-fit:contain}.month{font-size:12px;font-weight:700;color:#526b48;text-transform:uppercase}.names{font-size:12px;color:#555}
@media(max-width:1100px){.appShell{grid-template-columns:1fr}.sidebar,.sidebar.right{border:0}.stage{order:-1}.topbar{padding:0 18px}.brandName{font-size:32px}nav a{display:none}#guideGrid{grid-template-columns:repeat(2,1fr)}}