@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Bebas+Neue&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#F5F3EE;
  --surface:#FFFFFF;
  --accent:#1A4A2E;
  --accent2:#2D7A4F;
  --accent-light:#E8F2EC;
  --text:#1C1C1A;
  --text2:#5A5A55;
  --text3:#8A8A84;
  --border:#E0DDD5;
  --tag-bg:#EAF3DE;
  --tag-text:#27500A;
  --price:#C84B0E;
  --radius:12px;
  --radius-sm:8px;
  --admin-accent:#2C1F6B;
  --admin-accent2:#4A3BA8;
}

body{font-family:'Noto Sans JP',sans-serif;background:var(--bg);color:var(--text);min-height:100vh}

/* NAV */
nav{background:var(--accent);padding:0 2rem;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}
.logo{font-family:'Bebas Neue',sans-serif;font-size:28px;color:#fff;letter-spacing:.08em;text-decoration:none}
.logo span{color:#7DC997;font-size:22px;margin-left:2px}
.nav-right{display:flex;gap:12px;align-items:center}
.nav-link{color:rgba(255,255,255,.75);font-size:13px;text-decoration:none;transition:color .2s}
.nav-link:hover{color:#fff}
.nav-btn{background:var(--accent2);color:#fff;border:none;border-radius:var(--radius-sm);padding:6px 16px;font-size:13px;font-family:inherit;cursor:pointer;text-decoration:none;display:inline-block;transition:background .2s}
.nav-btn:hover{background:#3A9660}

/* BUTTONS */
.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:8px 20px;font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;transition:background .2s;text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.btn-primary:hover{background:var(--accent2)}
.btn-secondary{background:var(--surface);color:var(--text2);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:7px 16px;font-size:13px;font-family:inherit;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}

/* BADGES */
.badge{font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;white-space:nowrap}
.badge-green{background:var(--accent-light);color:var(--accent)}
.badge-red{background:#FCEBEB;color:#A32D2D}
.badge-amber{background:#FAEEDA;color:#854F0B}
.badge-blue{background:#E6F1FB;color:#185FA5}
.badge-gray{background:#F1EFE8;color:#5F5E5A}

/* CARD */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}

/* FORM */
.form-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.form-label{font-size:12px;font-weight:500;color:var(--text2)}
.form-label .required{color:var(--price);margin-left:2px}
.form-input,.form-select,.form-textarea{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;font-size:14px;font-family:inherit;color:var(--text);background:var(--bg);outline:none;transition:border-color .2s;width:100%}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent2)}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%238A8A84'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.form-textarea{resize:vertical;min-height:90px;line-height:1.7}

/* TABLE */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
thead th{font-size:11px;font-weight:500;color:var(--text3);text-align:left;padding:10px 14px;background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap}
tbody tr{border-bottom:1px solid var(--border);transition:background .15s}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:#FAFAF7}
td{padding:12px 14px;font-size:13px;color:var(--text);vertical-align:middle}

/* TOGGLE */
.toggle{position:relative;width:42px;height:24px;cursor:pointer;flex-shrink:0;display:inline-block}
.toggle input{opacity:0;width:0;height:0;position:absolute}
.toggle-track{position:absolute;inset:0;border-radius:12px;background:var(--border);transition:background .2s}
.toggle input:checked~.toggle-track{background:var(--accent2)}
.toggle-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle input:checked~.toggle-thumb{transform:translateX(18px)}

/* FOOTER */
footer{background:var(--accent);color:rgba(255,255,255,.55);text-align:center;padding:2rem;font-size:13px;margin-top:3rem}
footer strong{color:#fff;font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:.06em;display:block;margin-bottom:4px}

/* ALERT */
.alert{padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:16px}
.alert-success{background:var(--accent-light);color:var(--accent);border:1px solid #b3d9bf}
.alert-error{background:#FCEBEB;color:#A32D2D;border:1px solid #f5b8b8}
