:root{

  --bg:#f5f0e8;--bg2:#ede5d8;--card:#fff;--surface:#f9f5ee;

  --border:rgba(120,90,50,.12);--border-h:rgba(120,90,50,.25);

  --text:#2c2416;--text2:#7a6b52;--text3:#a89878;

  --wood:#5c3d1e;--wood2:#8b6840;--wood-light:#c4a06a;

  --indigo:#2b4570;--indigo2:#3d5a8a;--vermilion:#c53d2d;--gold:#b8941e;

  --ok:#3a7d44;--warn:#b8941e;--ng:#c53d2d;

  --r:6px;

  --serif:'Noto Serif JP',serif;--sans:'Noto Sans JP',sans-serif

}

*{box-sizing:border-box;margin:0;padding:0}

body{background:var(--bg);font-family:var(--sans);color:var(--text);min-height:100vh;display:flex;flex-direction:column}

::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}



@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}

.anim{animation:fadeUp .45s ease-out both}.d1{animation-delay:.06s}.d2{animation-delay:.12s}.d3{animation-delay:.18s}.d4{animation-delay:.24s}



/* ===== LOGIN ===== */

.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;

  background:var(--bg);

  background-image:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23c4a06a' fill-opacity='0.06'%3E%3Cpath d='M20 0L0 20h8l12-12 12 12h8z'/%3E%3C/g%3E%3C/svg%3E")}

.login-box{position:relative;z-index:1;width:380px;max-width:92vw;background:var(--card);border:2px solid var(--wood-light);border-radius:var(--r);overflow:hidden;animation:fadeUp .5s ease-out;box-shadow:0 8px 32px rgba(92,61,30,.12)}

.login-top{padding:32px 24px 18px;text-align:center;background:linear-gradient(180deg,rgba(196,160,106,.08),transparent);border-bottom:2px solid var(--wood-light)}

.login-crest{font-size:2.2rem;margin-bottom:8px;display:block}

.login-top h2{font-family:var(--serif);font-size:1.3rem;font-weight:900;color:var(--wood);letter-spacing:.15em}

.login-top p{color:var(--text2);font-size:.8rem;margin-top:4px}

.login-body{padding:24px}

.login-body label{font-family:var(--serif);font-size:.75rem;font-weight:700;color:var(--wood2);letter-spacing:.08em;display:block;margin-bottom:6px}

.login-err{color:var(--vermilion);font-size:.8rem;margin-top:8px;display:none}



/* FORM */

select,input[type=text],input[type=date],input[type=email],input[type=password],textarea{width:100%;background:var(--surface);border:1.5px solid var(--border);color:var(--text);border-radius:4px;padding:10px 12px;font-size:.88rem;font-family:var(--sans);transition:all .2s;outline:none}

select:focus,input:focus,textarea:focus{border-color:var(--indigo);box-shadow:0 0 0 3px rgba(43,69,112,.1)}

textarea{resize:vertical}



/* BUTTONS */

.btn-a{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:#d94030;color:#fff;border:none;border-radius:4px;font-weight:700;font-size:.85rem;padding:10px 22px;cursor:pointer;transition:all .2s;font-family:var(--sans)}

.btn-a:hover{background:#c53528;box-shadow:0 4px 12px rgba(217,64,48,.3)}

.btn-g{display:inline-flex;align-items:center;gap:6px;background:var(--card);border:1.5px solid var(--border);color:var(--text2);border-radius:4px;font-weight:600;padding:8px 16px;cursor:pointer;transition:all .2s;font-family:var(--sans);font-size:.84rem}

.btn-g:hover{border-color:var(--wood2);color:var(--wood)}

.btn-ok{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--ok);color:#fff;border:none;border-radius:4px;font-weight:700;padding:10px 22px;cursor:pointer;font-family:var(--sans);font-size:.85rem}

.btn-ok:hover{box-shadow:0 4px 12px rgba(58,125,68,.25)}

.btn-ng{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--vermilion);color:#fff;border:none;border-radius:4px;font-weight:700;padding:10px 22px;cursor:pointer;font-family:var(--sans);font-size:.85rem}

.btn-ng:hover{box-shadow:0 4px 12px rgba(197,61,45,.25)}

.btn-sm{font-size:.75rem;padding:5px 12px}

.btn-del{display:inline-flex;align-items:center;gap:4px;background:transparent;border:1.5px solid rgba(197,61,45,.25);color:var(--vermilion);border-radius:4px;font-size:.72rem;padding:4px 10px;cursor:pointer;transition:all .2s;font-family:var(--sans);font-weight:600}

.btn-del:hover{background:rgba(197,61,45,.06);border-color:var(--vermilion)}



/* STATUS */

.st{padding:3px 10px;border-radius:3px;font-size:.7rem;font-weight:700;display:inline-flex;align-items:center;gap:4px;font-family:var(--sans)}

.st::before{content:'';width:5px;height:5px;border-radius:50%}

.st-ok{background:rgba(58,125,68,.08);color:var(--ok)}.st-ok::before{background:var(--ok)}

.st-pn{background:rgba(184,148,30,.08);color:var(--warn)}.st-pn::before{background:var(--warn);animation:pulse 2s infinite}

.st-ng{background:rgba(197,61,45,.08);color:var(--ng)}.st-ng::before{background:var(--ng)}

.lv-badge{padding:2px 8px;border-radius:3px;font-size:.68rem;font-weight:700}

.lv-l3{background:rgba(43,69,112,.08);color:var(--indigo)}

.lv-l4{background:rgba(184,148,30,.08);color:var(--warn)}

.lv-l5{background:rgba(58,125,68,.08);color:var(--ok)}

.lv-admin{background:rgba(197,61,45,.08);color:var(--ng)}



/* ===== TOPBAR ===== */

.topbar{position:sticky;top:0;z-index:100;height:50px;background:rgba(245,240,232,.95);backdrop-filter:blur(12px);border-bottom:2px solid var(--wood-light);padding:0 16px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 8px rgba(92,61,30,.06)}

.tb-brand{display:flex;align-items:center;gap:8px;cursor:pointer}

.tb-brand-icon{font-size:1.2rem}

.tb-brand-text{font-family:var(--serif);font-size:.9rem;font-weight:900;color:var(--wood);letter-spacing:.08em}

.tb-nav{display:flex;gap:2px}

.tb-n{padding:6px 12px;border-radius:4px;color:var(--text2);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:5px;border:1px solid transparent;text-decoration:none}

.tb-n:hover{color:var(--wood);background:rgba(196,160,106,.08);border-color:rgba(196,160,106,.15)}

.tb-n.on{color:#d94030;background:rgba(217,64,48,.05);border-color:rgba(217,64,48,.15)}

.tb-n .dot{width:16px;height:16px;background:var(--vermilion);border-radius:50%;font-size:.6rem;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;animation:pulse 2s infinite}

.tb-right{display:flex;align-items:center;gap:8px}

.tb-user{display:flex;align-items:center;gap:6px;padding:3px 10px 3px 3px;border-radius:4px;background:var(--surface);border:1px solid var(--border)}

.tb-av{width:26px;height:26px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;color:#fff;background:var(--indigo)}

.tb-user span{font-size:.78rem;color:var(--text2)}

.tb-out{width:28px;height:28px;border-radius:4px;background:transparent;border:1.5px solid var(--border);color:var(--text3);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:12px}

.tb-out:hover{border-color:var(--vermilion);color:var(--vermilion)}



/* TOAST */

.toast-c{position:fixed;top:60px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:6px}

.toast-i{background:var(--card);border:1.5px solid var(--border);border-radius:var(--r);padding:12px 16px;min-width:280px;max-width:400px;display:flex;align-items:center;gap:10px;box-shadow:0 4px 16px rgba(92,61,30,.1);animation:fadeUp .35s ease-out}

.toast-i.s{border-left:3px solid var(--ok)}.toast-i.w{border-left:3px solid var(--warn)}.toast-i.e{border-left:3px solid var(--vermilion)}.toast-i.i{border-left:3px solid var(--indigo)}

.toast-i .ic{font-size:1rem}.toast-i.s .ic{color:var(--ok)}.toast-i.w .ic{color:var(--warn)}.toast-i.e .ic{color:var(--vermilion)}.toast-i.i .ic{color:var(--indigo)}

.toast-i .msg{font-size:.82rem;flex:1}.toast-i .x{color:var(--text3);cursor:pointer;font-size:.8rem}



/* MAIN */

.main{padding:16px 16px 0;max-width:1200px;margin:0 auto;flex:1}

.view{display:none}.view.on{display:block}

.crd{background:var(--card);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:0 1px 4px rgba(92,61,30,.04)}

.crd-h{padding:12px 16px;border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:rgba(196,160,106,.03)}

.crd-h h3{font-family:var(--serif);font-size:.88rem;font-weight:700;display:flex;align-items:center;gap:8px;margin:0}

.crd-b{padding:16px}



/* ===== BOARD ===== */

.board-title{text-align:center;margin-bottom:14px}

.board-title h2{font-family:var(--serif);font-size:1.1rem;font-weight:900;color:var(--wood);letter-spacing:.12em}

.board-title p{color:var(--text3);font-size:.78rem;margin-top:4px}

.board-outer{position:relative;border-radius:var(--r);overflow:hidden;min-height:420px;background:linear-gradient(135deg,#d4c4a0 0%,#bfad82 100%);

  max-width:720px;margin:0 auto;

  border:3px solid #8b6840;

  box-shadow:0 4px 20px rgba(92,61,30,.15)}

.board-outer img.bg{width:100%;display:block;filter:brightness(1.02) contrast(1.02)}

.board-wood{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at center,transparent 65%,rgba(92,61,30,.08) 100%)}

.zone-grid{position:absolute;inset:0;display:grid;gap:6px;padding:10px}

.zone-grid.g4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}

.zone-grid.g6{grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr}



/* Empty slot */

.zone{border:2px dashed rgba(255,255,255,.35);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;position:relative;transition:all .2s;

  transition:all .25s;position:relative;overflow:visible;cursor:pointer;background:rgba(255,255,255,.08)}

.zone:hover{background:rgba(255,255,255,.2);border-color:rgba(92,61,30,.4);box-shadow:0 0 12px rgba(196,160,106,.15)}

.zone .z-label{font-family:var(--serif);font-size:.75rem;color:rgba(255,255,255,.6);font-weight:700;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,.15)}

.zone .z-icon{font-size:1.6rem;pointer-events:none;color:rgba(255,255,255,.5)}

.zone:hover .z-label{color:rgba(255,255,255,.9)}.zone:hover .z-icon{color:rgba(255,255,255,.8)}

.zone.drag-over{background:rgba(43,69,112,.2)!important;border:2.5px dashed var(--indigo)!important;box-shadow:0 0 16px rgba(43,69,112,.25)}



/* Filled slot */

.zone.filled{cursor:default;background:rgba(255,255,255,.85);border:1.5px solid rgba(92,61,30,.2);box-shadow:1px 2px 6px rgba(0,0,0,.08);backdrop-filter:blur(2px)}

.zone.filled:hover{box-shadow:2px 3px 12px rgba(0,0,0,.12);border-color:var(--wood-light)}

.zone.filled .z-label,.zone.filled .z-icon{display:none}

.zone .z-posting{position:absolute;inset:0;display:flex;flex-direction:column}

.zone .z-img{flex:1;overflow:hidden;display:flex;align-items:center;justify-content:center}

.zone .z-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}

.zone.filled:hover .z-img img{transform:scale(1.03)}

.zone .z-info{padding:4px 8px;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border)}

.zone .z-info .z-title{font-family:var(--serif);font-size:.66rem;font-weight:700;color:var(--wood);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.zone .z-del{position:absolute;top:3px;right:3px;z-index:5;width:20px;height:20px;background:rgba(197,61,45,.85);border:none;border-radius:3px;color:#fff;font-size:10px;cursor:pointer;display:none;align-items:center;justify-content:center}

.zone.filled:hover .z-del.can-del{display:flex}



.layout-toggle{display:flex;background:var(--surface);border-radius:4px;padding:3px;gap:2px;border:1px solid var(--border)}

.lt-btn{padding:5px 14px;border-radius:3px;font-size:.72rem;font-weight:600;color:var(--text2);cursor:pointer;transition:all .2s;border:none;background:transparent;font-family:var(--sans);display:flex;align-items:center;gap:4px}

.lt-btn:hover{color:var(--wood)}.lt-btn.on{background:#3a3028;color:#fff}



/* STAT BAR */

.stat-bar{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}

.stat-item{flex:1;min-width:130px;background:var(--card);border:1.5px solid var(--border);border-radius:var(--r);padding:10px 14px;display:flex;align-items:center;gap:10px;box-shadow:0 1px 3px rgba(92,61,30,.04)}

.stat-icon{font-size:1.2rem}.stat-info{flex:1}

.stat-label{font-size:.65rem;font-weight:600;color:var(--text3);letter-spacing:.04em}

.stat-val{font-size:1rem;font-weight:800;margin-top:1px}



/* OVERLAYS */

.overlay{position:fixed;inset:0;z-index:200;background:rgba(44,36,22,.5);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center}

.overlay.show{display:flex}

.obox{width:480px;max-width:92vw;max-height:90vh;overflow-y:auto;background:var(--card);border:2px solid var(--wood-light);border-radius:var(--r);animation:fadeUp .3s ease-out;box-shadow:0 12px 40px rgba(92,61,30,.18)}

.obox.wide{width:640px}

.ohead{padding:14px 18px;border-bottom:2px solid var(--wood-light);display:flex;align-items:center;justify-content:space-between;background:rgba(196,160,106,.04)}

.ohead h3{font-family:var(--serif);font-size:.92rem;font-weight:700;display:flex;align-items:center;gap:8px;margin:0}

.oclose{width:28px;height:28px;border-radius:4px;border:1.5px solid var(--border);background:transparent;color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;font-size:13px}

.oclose:hover{border-color:var(--vermilion);color:var(--vermilion)}

.obody{padding:20px}

.field{margin-bottom:14px}

.field label{font-size:.75rem;font-weight:700;color:var(--wood2);display:block;margin-bottom:5px}



/* DROP AREA */

.drop-area{border:2px dashed var(--border);border-radius:var(--r);padding:24px;text-align:center;cursor:pointer;transition:all .25s;background:var(--surface)}

.drop-area:hover,.drop-area.active{border-color:var(--indigo);background:rgba(43,69,112,.03)}

.drop-area .da-icon{font-size:1.6rem;color:var(--text3);margin-bottom:4px}

.drop-area .da-text{font-size:.8rem;color:var(--text2)}

.drop-area .da-hint{font-size:.7rem;color:var(--text3);margin-top:3px}

.drop-area.has-img{padding:6px}

.drop-area.has-img img{width:100%;border-radius:4px;max-height:160px;object-fit:contain}



/* MGR CHIPS */

.mgr-row{display:flex;gap:8px;flex-wrap:wrap}

.mgr-chip{padding:8px 12px;border-radius:4px;border:1.5px solid var(--border);background:var(--surface);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;font-size:.8rem}

.mgr-chip:hover{border-color:var(--indigo);background:rgba(43,69,112,.04)}

.mgr-chip.sel{border-color:var(--indigo);background:rgba(43,69,112,.06);box-shadow:0 0 0 2px rgba(43,69,112,.1)}

.mgr-chip .mc-av{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700;color:#fff}

.mgr-chip .mc-check{color:var(--indigo);display:none;font-size:.85rem}.mgr-chip.sel .mc-check{display:block}



/* TABLE */

.tbl{width:100%;border-collapse:collapse}

.tbl th{font-size:.7rem;font-weight:700;color:var(--wood2);padding:10px 12px;border-bottom:2px solid var(--wood-light);background:rgba(196,160,106,.04);text-align:left}

.tbl td{padding:10px 12px;font-size:.82rem;border-bottom:1px solid var(--border);vertical-align:middle}

.tbl tbody tr{transition:all .15s;cursor:pointer}.tbl tbody tr:hover{background:rgba(196,160,106,.04)}

.ftabs{display:flex;gap:2px;background:var(--surface);padding:3px;border-radius:4px;width:fit-content;margin-bottom:14px;border:1px solid var(--border)}

.ftab{padding:5px 14px;border-radius:3px;font-size:.75rem;font-weight:600;color:var(--text2);cursor:pointer;border:none;background:transparent;transition:all .2s;font-family:var(--sans)}

.ftab:hover{color:var(--wood)}.ftab.on{background:#3a3028;color:#fff}



/* APPROVAL / MEMBER */

.ap-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);padding:12px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}

.ap-card.me{border-color:rgba(43,69,112,.25);background:rgba(43,69,112,.03)}

.mem-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid var(--border);transition:all .15s}

.mem-row:hover{background:rgba(196,160,106,.04)}.mem-row:last-child{border-bottom:none}

.mem-av{width:32px;height:32px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;color:#fff;flex-shrink:0}

.mem-info{flex:1;min-width:0}

.mem-info .nm{font-size:.84rem;font-weight:700}.mem-info .meta{font-size:.72rem;color:var(--text3)}



/* MISC */

.li-dark{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:all .15s;color:var(--text)}

.li-dark:hover{background:rgba(196,160,106,.04)}.li-dark:last-child{border-bottom:none}

.empty{text-align:center;padding:28px;color:var(--text3);font-size:.84rem}

.empty i{font-size:1.6rem;display:block;margin-bottom:6px;opacity:.4}

.sec{font-size:.72rem;font-weight:700;color:var(--wood2);letter-spacing:.04em;display:flex;align-items:center;gap:6px;margin-bottom:10px}



.confirm-del{background:rgba(197,61,45,.04);border:1.5px solid rgba(197,61,45,.15);border-radius:var(--r);padding:14px;margin-top:12px;text-align:center}

@media(max-width:768px){.tb-nav{display:none}.main{padding:10px}.stat-bar{flex-direction:column}}

