:root{
  --paper:#efe0bd; --paper2:#e7d4a8; --card:#fbf4e1; --card2:#f6ecd2;
  --red:#b5322a; --red-d:#95271f; --green:#3f7d34; --green-d:#2f6327;
  --blue:#2a5f8f; --blue-d:#1f4a70; --orange:#e0821e; --gold:#f2c236;
  --purple:#6b3fa0; --pink:#c2417a; --brown:#5a3a22; --ink:#4a3218;
  --line:#cdb079; --dash:#b9985e;
  --sh:0 8px 24px rgba(74,50,24,.16); --sh-sm:0 3px 10px rgba(74,50,24,.14);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Nunito',system-ui,sans-serif;color:var(--ink);line-height:1.55;
  background-color:var(--paper);
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E"),
    radial-gradient(circle at 30% 8%, rgba(255,255,255,.35), transparent 55%),
    linear-gradient(160deg,var(--paper),var(--paper2));
  position:relative;overflow-x:hidden;
}
.rye{font-family:'Rye',serif}
.script{font-family:'Pacifico',cursive}

/* ---------------- Decor corners ---------------- */
.decor{position:fixed;pointer-events:none;z-index:0;font-size:64px;filter:drop-shadow(2px 4px 3px rgba(0,0,0,.22));opacity:.95}
.d-lantern{top:74px;left:-6px;font-size:70px;transform:rotate(-6deg)}
.d-hat{top:80px;right:-8px;font-size:66px;transform:rotate(12deg)}
.d-sun1{bottom:8px;left:-10px;font-size:80px;transform:rotate(-8deg)}
.d-cactus{bottom:90px;left:6px;font-size:52px}
.d-sun2{bottom:70px;right:-6px;font-size:78px;transform:rotate(10deg)}
.d-fire{bottom:14px;right:14px;font-size:46px}
@media(max-width:820px){.decor{font-size:44px!important;opacity:.6}.d-cactus,.d-fire{display:none}}

/* ---------------- Bunting ---------------- */
.topstring{position:relative;z-index:1;padding:10px 0 2px;background:linear-gradient(#e3cf9e,transparent)}
.lights{display:flex;justify-content:center;gap:26px;height:14px;margin-bottom:-4px}
.lights i{width:9px;height:9px;border-radius:50%;display:block;animation:blink 2.2s infinite}
.lights i:nth-child(4n){background:var(--gold);box-shadow:0 0 8px var(--gold)}
.lights i:nth-child(4n+1){background:#ff7b5e;box-shadow:0 0 8px #ff7b5e}
.lights i:nth-child(4n+2){background:#7ec8ff;box-shadow:0 0 8px #7ec8ff}
.lights i:nth-child(4n+3){background:#8ef08a;box-shadow:0 0 8px #8ef08a}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}
.bunting{display:flex;justify-content:center;flex-wrap:wrap;gap:0;position:relative}
.bunting::before{content:"";position:absolute;top:3px;left:2%;right:2%;height:3px;background:var(--brown);border-radius:2px;opacity:.7}
.flag{
  width:38px;height:46px;margin:0 1px;
  clip-path:polygon(0 0,100% 0,100% 100%,50% 74%,0 100%);
  box-shadow:inset 0 -3px 6px rgba(0,0,0,.12);
  transform-origin:top center;animation:sway 3.4s ease-in-out infinite;
}
@keyframes sway{0%,100%{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}
.f-red{background:var(--red)}
.f-green{background:var(--green)}
.f-blue{background:var(--blue)}
.f-gold{background:var(--gold)}
.f-gingham{background:#fff;background-image:
  repeating-linear-gradient(0deg,rgba(181,50,42,.5) 0 7px,transparent 7px 14px),
  repeating-linear-gradient(90deg,rgba(181,50,42,.5) 0 7px,transparent 7px 14px)}
.f-gingham-b{background:#fff;background-image:
  repeating-linear-gradient(0deg,rgba(42,95,143,.5) 0 7px,transparent 7px 14px),
  repeating-linear-gradient(90deg,rgba(42,95,143,.5) 0 7px,transparent 7px 14px)}
.f-dot{background:var(--red);background-image:radial-gradient(#fff 24%,transparent 26%),radial-gradient(#fff 24%,transparent 26%);background-size:16px 16px;background-position:0 0,8px 8px}
.f-dot-g{background:var(--green);background-image:radial-gradient(#fff 24%,transparent 26%),radial-gradient(#fff 24%,transparent 26%);background-size:16px 16px;background-position:0 0,8px 8px}

/* ---------------- Layout ---------------- */
.wrap{max-width:800px;margin:0 auto;padding:0 16px 40px;position:relative;z-index:1}

/* ---------------- Hero ---------------- */
.hero{text-align:center;padding:18px 6px 6px}
.kicker{letter-spacing:4px;font-weight:800;font-size:13px;color:var(--brown)}
.ribbon{
  display:inline-block;position:relative;margin:8px 0 2px;padding:10px 40px;
  background:var(--red);color:#fff;font-family:'Rye',serif;
  font-size:clamp(26px,7vw,46px);line-height:1;
  border:2px dashed rgba(255,255,255,.55);border-radius:6px;
  box-shadow:var(--sh);text-shadow:1px 2px 0 var(--red-d);
}
.ribbon::before,.ribbon::after{content:"";position:absolute;top:50%;width:22px;height:130%;background:var(--red-d);transform:translateY(-50%);z-index:-1}
.ribbon::before{left:-14px;clip-path:polygon(0 50%,100% 0,100% 100%)}
.ribbon::after{right:-14px;clip-path:polygon(100% 50%,0 0,0 100%)}
.para{display:block;font-family:'Pacifico',cursive;color:var(--brown);font-size:clamp(20px,5vw,30px);margin:6px 0 0;transform:rotate(-2deg)}
.festejar{font-family:'Ultra',serif;font-size:clamp(40px,12vw,84px);line-height:.95;margin:2px 0 4px;letter-spacing:1px}
.festejar span{-webkit-text-stroke:2px var(--brown);paint-order:stroke fill;text-shadow:3px 4px 0 rgba(90,58,34,.25)}
.festejar span:nth-child(1){color:var(--green)}
.festejar span:nth-child(2){color:var(--orange)}
.festejar span:nth-child(3){color:var(--blue)}
.festejar span:nth-child(4){color:var(--red)}
.festejar span:nth-child(5){color:var(--purple)}
.festejar span:nth-child(6){color:var(--gold)}
.festejar span:nth-child(7){color:var(--green)}
.festejar span:nth-child(8){color:var(--pink)}

/* ---------------- Motivos ---------------- */
.motivos{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin:20px 0 6px;
  background:var(--card);border:2px dashed var(--dash);border-radius:18px;box-shadow:var(--sh);overflow:hidden}
.motivo{padding:18px 10px 20px;text-align:center;position:relative}
.motivo+.motivo{border-left:2px dashed var(--dash)}
.pennant{display:inline-block;background:var(--green);color:#fff;font-family:'Rye';font-size:14px;
  padding:4px 12px 9px;clip-path:polygon(0 0,100% 0,100% 100%,50% 78%,0 100%);box-shadow:var(--sh-sm)}
.motivo:nth-child(2) .pennant{background:var(--blue)}
.motivo:nth-child(3) .pennant{background:var(--purple)}
.motivo .emoji{font-size:44px;display:block;margin:8px 0 6px;filter:drop-shadow(1px 3px 2px rgba(0,0,0,.2))}
.motivo b{display:block;font-family:'Rye';font-size:16px;line-height:1.15}
.motivo:nth-child(1) b{color:var(--green)}
.motivo:nth-child(2) b{color:var(--blue)}
.motivo:nth-child(3) b{color:var(--pink)}
.motivo:nth-child(3) .script{font-size:22px;display:block;margin-top:2px}

/* ---------------- Detalhes ---------------- */
.detalhes{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin:14px 0 4px;
  background:var(--card2);border:2px dashed var(--dash);border-radius:16px;box-shadow:var(--sh-sm);overflow:hidden}
.det{padding:14px 8px;text-align:center}
.det+.det{border-left:2px dashed var(--dash)}
.det .ic{font-size:26px}
.det .lbl{font-size:11px;letter-spacing:2px;font-weight:800;color:var(--brown);opacity:.7;margin-top:2px}
.det .val{font-family:'Rye';font-size:20px;color:var(--blue)}
.det .sub{font-size:12px;opacity:.85;line-height:1.25}

/* ---------------- Sections ---------------- */
.block{background:var(--card);border:2px dashed var(--dash);border-radius:20px;padding:22px 20px;margin-top:22px;box-shadow:var(--sh);position:relative}
.block::before{content:"";position:absolute;top:-2px;left:24px;right:24px;height:6px;border-radius:0 0 6px 6px;
  background:repeating-linear-gradient(90deg,var(--red) 0 12px,var(--gold) 12px 24px,var(--green) 24px 36px,var(--blue) 36px 48px)}
.block>h2{font-family:'Rye';color:var(--red);font-size:23px;margin-bottom:4px;display:flex;align-items:center;gap:9px}
.block>p.hint{font-size:13.5px;opacity:.85;margin-bottom:14px}

/* ---------------- Form ---------------- */
label{font-weight:800;font-size:13px;display:block;margin:12px 0 5px;color:var(--brown)}
select,input[type=text],input[type=number]{
  width:100%;padding:12px 14px;border:2px solid var(--line);border-radius:12px;
  font:inherit;background:#fffdf6;color:var(--ink);box-shadow:inset 0 2px 4px rgba(0,0,0,.04)}
select:focus,input:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(224,130,30,.2)}
.row{display:flex;gap:12px;flex-wrap:wrap}.row>div{flex:1;min-width:150px}
.btns{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}
button{font:inherit;font-weight:800;cursor:pointer;border:none;padding:13px 20px;border-radius:12px;color:#fff;
  box-shadow:0 4px 0 rgba(0,0,0,.18),var(--sh-sm);transition:.12s transform,.12s box-shadow}
button:active{transform:translateY(3px);box-shadow:0 1px 0 rgba(0,0,0,.18)}
.btn-sim{background:linear-gradient(var(--green),var(--green-d))}
.btn-nao{background:linear-gradient(var(--red),var(--red-d))}
.btn-orange{background:linear-gradient(var(--orange),#c46f12)}
.btn-ghost{background:#fffdf6;color:var(--brown);border:2px solid var(--line);box-shadow:var(--sh-sm)}
.aviso .btns a.btn-orange{text-decoration:none;display:inline-block}

/* ---------------- Acompanhantes ---------------- */
.comp-row{display:flex;gap:8px;margin-bottom:8px;align-items:center}
.comp-row input{flex:1}
.btn-x{background:var(--red);color:#fff;padding:10px 14px;flex:0 0 auto;box-shadow:none}
.total-people{margin-top:14px;font-family:'Rye';font-size:16px;color:var(--blue)}

/* ---------------- Admin: comidas editáveis ---------------- */
.food-admin-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:#fffdf6;border:2px solid var(--line);border-radius:12px;padding:10px 13px;margin-bottom:8px}
.food-admin-row .fa-name{font-weight:800;flex:1;min-width:120px}
.food-admin-row .fa-count{font-size:12px;font-weight:800;background:var(--green);color:#fff;border-radius:20px;padding:3px 10px;white-space:nowrap}
.food-admin-row button{padding:7px 13px;font-size:12.5px}
.comp-admin{font-size:12.5px;opacity:.85}
.msg{margin-top:14px;padding:11px 15px;border-radius:12px;font-weight:800;font-size:14px;display:none}
.msg.ok{display:block;background:#e4f2df;color:var(--green-d);border:2px dashed var(--green)}
.msg.err{display:block;background:#f8e0dc;color:var(--red-d);border:2px dashed var(--red)}

/* ---------------- Stats ---------------- */
.stats{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}
.stat{flex:1;background:#fffdf6;border:2px dashed var(--line);border-radius:14px;padding:12px;text-align:center;min-width:96px;box-shadow:var(--sh-sm)}
.stat b{display:block;font-family:'Rye';font-size:26px;color:var(--green-d)}
.stat.no b{color:var(--red)}.stat.pp b{color:var(--blue)}.stat.pen b{color:#b8912f}
.stat span{font-size:10.5px;letter-spacing:1px;text-transform:uppercase;opacity:.75;font-weight:800}

/* ---------------- Comidas ---------------- */
.cat{margin-top:18px}
.cat-title{display:inline-block;font-family:'Rye';font-size:16px;color:#fff;background:var(--orange);
  padding:5px 16px 8px;clip-path:polygon(0 0,100% 0,96% 100%,4% 100%);box-shadow:var(--sh-sm);margin-bottom:10px}
.cat:nth-of-type(2) .cat-title{background:var(--pink)}
.cat:nth-of-type(3) .cat-title{background:var(--green)}
.cat:nth-of-type(4) .cat-title{background:var(--blue)}
.cat:nth-of-type(5) .cat-title{background:var(--purple)}
.food{background:#fffdf6;border:2px solid var(--line);border-radius:14px;padding:13px 15px;margin-bottom:9px;box-shadow:var(--sh-sm);transition:.15s border-color}
.food.mine{border-color:var(--green);border-style:dashed;background:#f4faef}
.food .top{display:flex;justify-content:space-between;align-items:center;gap:8px}
.food .name{font-weight:800;font-size:15px}
.food .count{font-size:12px;font-weight:800;background:var(--green);color:#fff;border-radius:20px;padding:3px 12px;white-space:nowrap;box-shadow:var(--sh-sm)}
.food .count.zero{background:#cdb079}
.food .who{margin-top:8px}
.food .chip{display:inline-block;background:var(--card2);border:1px solid var(--line);border-radius:20px;padding:3px 11px;margin:3px 4px 0 0;font-size:12px;font-weight:700}
.food .chip.me{background:var(--gold);border-color:var(--orange);font-weight:800}
.food .act{margin-top:10px}
.food .act button{padding:8px 16px;font-size:13px}

/* ---------------- Brincadeiras ---------------- */
.games{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.game{background:#fffdf6;border:2px solid var(--line);border-radius:14px;padding:14px;text-align:center;box-shadow:var(--sh-sm);transition:.15s transform}
.game:hover{transform:translateY(-3px) rotate(-1deg)}
.game .g-ic{font-size:32px;filter:drop-shadow(1px 2px 1px rgba(0,0,0,.15))}
.game .g-nm{font-family:'Rye';margin:6px 0 3px;font-size:14px;color:var(--red)}
.game .g-ds{font-size:12px;opacity:.85}

/* ---------------- Avisos ---------------- */
.aviso{border-radius:16px;padding:18px 20px;margin-top:22px;text-align:center;box-shadow:var(--sh);position:relative}
.aviso.purple{background:linear-gradient(var(--purple),#553191);color:#fff}
.aviso.green{background:linear-gradient(var(--green),var(--green-d));color:#fff}
.aviso.kraft{background:var(--card2);color:var(--brown);border:2px dashed var(--brown)}
.aviso h3{font-family:'Rye';font-size:21px;margin-bottom:5px}
.aviso b.blue{color:#a8ddff}.aviso b.pink{color:#ffc7e2}.aviso b.gold{color:var(--gold)}

/* ---------------- Footer tablecloth ---------------- */
.tablecloth{margin-top:30px;height:70px;
  background:#fff;background-image:
    repeating-linear-gradient(0deg,rgba(181,50,42,.55) 0 18px,transparent 18px 36px),
    repeating-linear-gradient(90deg,rgba(181,50,42,.55) 0 18px,transparent 18px 36px);
  border-top:3px solid var(--red);position:relative;z-index:1}
footer{text-align:center;padding:20px 10px;font-size:13px;opacity:.75;position:relative;z-index:1}
footer a{color:var(--blue);font-weight:800}

@media(max-width:560px){
  .motivos,.detalhes{grid-template-columns:1fr}
  .motivo+.motivo,.det+.det{border-left:none;border-top:2px dashed var(--dash)}
}

/* ================= BOARD DE ORGANIZAÇÃO ================= */
.board-top{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:8px}
.board-top .prog{font-weight:800;font-size:13px;color:var(--brown)}
.board-top .bar{height:10px;background:#e6d3a6;border-radius:20px;overflow:hidden;flex:1;min-width:160px;max-width:340px;border:1px solid var(--line)}
.board-top .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--green),var(--gold));transition:.4s width}
.board{display:flex;gap:14px;overflow-x:auto;padding:6px 2px 18px;align-items:flex-start;scroll-snap-type:x proximity}
.list{background:var(--card2);border:2px dashed var(--dash);border-radius:16px;padding:12px;min-width:270px;max-width:290px;flex:0 0 auto;scroll-snap-align:start;box-shadow:var(--sh-sm)}
.list.dragover{border-color:var(--green);background:#f1f7ea}
.list-head{display:flex;justify-content:space-between;align-items:center;gap:6px;margin-bottom:10px}
.list-head .lt{font-family:'Rye';font-size:15px;color:var(--red);line-height:1.15}
.list-head .cnt{font-size:11px;font-weight:800;background:var(--brown);color:#fff;border-radius:20px;padding:2px 9px;white-space:nowrap}
.list-head .lx{background:none;box-shadow:none;color:var(--brown);opacity:.5;padding:2px 6px;font-size:15px}
.list-head .lx:hover{opacity:1;color:var(--red)}
.bcard{background:#fffdf6;border:2px solid var(--line);border-radius:12px;padding:10px 11px;margin-bottom:8px;box-shadow:var(--sh-sm);cursor:grab;display:flex;gap:9px;align-items:flex-start;transition:.12s transform}
.bcard:active{cursor:grabbing}
.bcard.done{background:#f0f5ea;border-color:var(--green);border-style:dashed}
.bcard.done .bc-text{text-decoration:line-through;opacity:.6}
.bcard .chk{width:20px;height:20px;border:2px solid var(--line);border-radius:6px;flex:0 0 auto;margin-top:1px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;color:#fff;background:#fffdf6}
.bcard.done .chk{background:var(--green);border-color:var(--green)}
.bcard .bc-body{flex:1;min-width:0}
.bcard .bc-text{font-weight:700;font-size:14px;word-break:break-word}
.bcard .bc-meta{margin-top:5px;display:flex;flex-wrap:wrap;gap:5px}
.bcard .tag{font-size:11px;font-weight:800;border-radius:20px;padding:2px 8px}
.bcard .tag.quem{background:var(--gold);color:var(--brown)}
.bcard .tag.link{background:var(--blue);color:#fff;text-decoration:none}
.bcard .tag.obs{background:var(--card2);border:1px solid var(--line);color:var(--brown)}
.addcard{width:100%;border:2px dashed var(--line);background:#fffdf6;border-radius:10px;padding:9px;font:inherit;color:var(--brown);cursor:text}
.addcard::placeholder{color:var(--brown);opacity:.6;font-weight:700}
.addlist{min-width:200px;flex:0 0 auto}
.addlist button{width:100%;background:var(--card2);color:var(--brown);border:2px dashed var(--dash);box-shadow:none}

/* modal editor */
.modal-bg{position:fixed;inset:0;background:rgba(50,32,14,.55);display:none;align-items:center;justify-content:center;z-index:50;padding:16px}
.modal-bg.on{display:flex}
.modal{background:var(--card);border:2px dashed var(--dash);border-radius:18px;padding:22px;max-width:440px;width:100%;box-shadow:var(--sh);max-height:90vh;overflow:auto}
.modal h3{font-family:'Rye';color:var(--red);margin-bottom:6px}
.modal textarea{width:100%;padding:11px 13px;border:2px solid var(--line);border-radius:12px;font:inherit;background:#fffdf6;resize:vertical;min-height:56px}
.modal .mbtns{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.modal .mbtns .grow{flex:1}
.btn-del{background:linear-gradient(var(--red),var(--red-d))}
