:root{
  --bg:#0a0a0a;
  --dim:rgba(255,255,255,0.35);
  --faint:rgba(255,255,255,0.07);
  --line:rgba(255,255,255,0.82);
}
*{margin:0;padding:0;box-sizing:border-box;}
html,body{background:var(--bg);color:var(--line);font-family:'Caveat',cursive;height:100%;overflow:hidden;}

.screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.55s ease;background:var(--bg);overflow:hidden;}
.screen.active{opacity:1;pointer-events:all;}

/* ============ INTRO ============ */
#screen-intro{flex-direction:column;align-items:center;gap:20px;}
.logo-main{width:min(240px,54vw);opacity:0;animation:fadeUp 1.4s ease 0.3s forwards;}
.tagline{font-size:13px;letter-spacing:5px;color:var(--dim);opacity:0;animation:fadeUp 1s ease 1.3s forwards;}
.enter{font-family:'Dancing Script',cursive;font-size:21px;color:var(--dim);letter-spacing:4px;cursor:pointer;opacity:0;animation:fadeUp 1s ease 1.9s forwards,pulse 2.6s ease 2.9s infinite;transition:color 0.2s;}
.enter:hover{color:var(--line);}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:translateY(0);}}
@keyframes pulse{0%,100%{opacity:0.32;}50%{opacity:0.78;}}

/* ============ SHARED LAYOUT ============ */
/* All main screens: logo top, big wardrobe below */
.wlayout{display:flex;flex-direction:column;align-items:center;width:100%;height:100vh;overflow:hidden;padding-top:14px;}
.logo-top{flex-shrink:0;text-align:center;margin-bottom:6px;}
.logo-sm{width:min(130px,28vw);display:inline-block;}
.sub-line{font-size:11px;letter-spacing:5px;color:var(--dim);margin-top:4px;}
/* Wardrobe container fills remaining height */
.wardrobe-stage{
  flex:1;min-height:0;
  display:flex;align-items:center;justify-content:center;
  width:100%;padding:0 12px 14px;
}
/* The wardrobe box itself — constrained by both width AND height */
.wardrobe-box{
  /* aspect ratio of new image: 790/912 = ~0.866 */
  aspect-ratio:790/912;
  /* fill as much as possible */
  width:min(72vh * 790/912, 94vw);
  /* fallback with max-width */
  max-width:min(700px, 94vw);
  position:relative;
  flex-shrink:0;
}

/* ============ DOOR ============ */
.wardrobe-door{
  width:100%;height:100%;
  position:relative;
  border:1.5px solid rgb(255, 255, 255);
  background:#0d0d0d;
  cursor:pointer;
  overflow:hidden;
  box-shadow:
    inset 0 0 100px rgba(0,0,0,0.96),
    0 30px 90px rgba(0,0,0,0.9),
    inset 1px 1px 0 rgba(255,255,255,0.04);
  transition:box-shadow 0.3s;
}
.wardrobe-door:hover{
  box-shadow:
    inset 0 0 100px rgba(0,0,0,0.92),
    0 30px 90px rgba(0,0,0,0.8),
    0 0 0 1px rgb(255, 255, 255);
}
/* subtle sheen */
.wardrobe-door::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(155deg,rgba(255,255,255,0.022) 0%,transparent 42%,rgba(0,0,0,0.1) 100%);
  pointer-events:none;z-index:1;
}
/* left panel = 36.1% (matches real image vertical divider) */
.d-left{position:absolute;top:0;bottom:0;left:0;width:50%;border-right:1.5px solid rgba(255,255,255,0.18);}
.d-right{position:absolute;top:0;bottom:0;left:50%;right:0;}
/* panel insets mirroring a real 2-panel wardrobe door */
.d-inset{position:absolute;border:1px solid rgba(255,255,255,0.09);box-shadow:inset 0 0 0 1px rgba(0,0,0,0.4);}
.d-left  .d-inset:nth-child(1){top:4%;left:8%;right:8%;height:40%;}
.d-left  .d-inset:nth-child(2){top:49%;left:8%;right:8%;bottom:4%;}
.d-right .d-inset:nth-child(1){top:4%;left:5%;right:5%;height:40%;}
.d-right .d-inset:nth-child(2){top:49%;left:5%;right:5%;bottom:4%;}
/* handles near the center seam */
.d-handle{position:absolute;top:50%;transform:translateY(-50%);width:7px;height:46px;border:1px solid rgba(255,255,255,0.22);border-radius:3px;background:linear-gradient(to right,rgba(255,255,255,0.05),rgba(255,255,255,0.01));}
.d-left  .d-handle{right:13px;}
.d-right .d-handle{left:13px;}
/* sticky notes */
.sticky-layer{position:absolute;inset:0;pointer-events:none;z-index:3;}
.sticky{
  position:absolute;padding:9px 11px 18px;
  font-family:'Caveat',cursive;font-size:12.5px;line-height:1.58;
  min-width:75px;max-width:115px;
  transform:rotate(var(--r));
  pointer-events:all;cursor:default;
  box-shadow:2px 4px 10px rgba(0,0,0,0.65);
  transition:transform 0.22s,box-shadow 0.22s;z-index:2;
}
.sticky:hover{transform:rotate(0deg) scale(1.07);box-shadow:4px 8px 20px rgba(0,0,0,0.75);z-index:30;}
.sticky-tape{position:absolute;top:-5px;left:50%;transform:translateX(-50%);width:26px;height:9px;border-radius:2px;background:rgba(0,0,0,0.14);border:1px solid rgba(0,0,0,0.07);}
.sticky-date{position:absolute;bottom:5px;left:11px;font-size:9.5px;opacity:0.46;letter-spacing:0.4px;}
.sc0{background:#f5e642;color:#191200;}.sc1{background:#f4a7b9;color:#26000c;}.sc2{background:#a8d8ea;color:#001018;}.sc3{background:#b5ead7;color:#001208;}.sc4{background:#ffd8b1;color:#190c00;}
.door-hint{font-size:11.5px;color:var(--dim);letter-spacing:3px;text-align:center;margin-top:10px;}

/* ============ OPEN WARDROBE ============ */
.wardrobe-img{width:100%;height:100%;object-fit:fill;display:block;}

/* HOTSPOTS */
.hs{position:absolute;cursor:pointer;}
.hs::after{content:'';position:absolute;inset:0;opacity:0;transition:opacity 0.18s;background:radial-gradient(ellipse at center,rgba(255,255,255,0.065) 0%,transparent 65%);pointer-events:none;}
.hs:hover::after{opacity:1;}
.hs-lbl{
  position:absolute;bottom:-23px;left:50%;transform:translateX(-50%);
  font-family:'Caveat',cursive;font-size:11.5px;color:rgba(255,255,255,0.55);
  white-space:nowrap;opacity:0;pointer-events:none;transition:opacity 0.17s;
  padding:1px 5px;letter-spacing:1px;border-bottom:1px solid rgba(255,255,255,0.18);
}
.hs:hover .hs-lbl{opacity:1;}
/* clothes sway */
.sway{position:absolute;width:5%;top:20%;height:32%;transform-origin:top center;animation:sway 3.8s ease-in-out infinite;pointer-events:none;}
@keyframes sway{0%,100%{transform:rotate(-1.6deg);}50%{transform:rotate(1.6deg);}}

/* ===== GIRL SPEECH BUBBLE ===== */
.bubble-wrap{position:absolute;z-index:10;pointer-events:none;}
.bubble{
  background:rgba(255,255,255,0.92);color:#1a1a1a;
  font-family:'Caveat',cursive;font-size:12px;line-height:1;
  padding:1px 10px;border-radius:10px 10px 10px 10px;
  max-width:110px;word-break:break-all;
  box-shadow:0 2px 8px rgba(0,0,0,0.35);
  animation:floatBubble 4s ease-in-out infinite;
  cursor:default;white-space:pre-wrap;
}
@keyframes floatBubble{0%,100%{transform:translateY(0);}50%{transform:translateY(-5px);}}
.bubble-title{font-size:10px;opacity:0.5;letter-spacing:1px;margin-bottom:2px;}

/* ============ TOPBAR ============ */
.topbar{position:fixed;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:12px 20px;z-index:80;pointer-events:none;}
.tb{font-size:13px;color:var(--dim);background:none;border:none;cursor:pointer;pointer-events:all;display:none;letter-spacing:2px;transition:color 0.2s;font-family:'Caveat',cursive;}
.tb:hover{color:var(--line);}

/* ============ NOTE BAR ============ */
.note-bar{position:fixed;bottom:0;left:0;right:0;background:rgba(5,5,5,0.97);border-top:1px solid var(--faint);padding:11px 22px;gap:11px;display:none;align-items:center;z-index:150;}
.note-bar.show{display:flex;}
.note-inp{flex:1;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,0.2);color:white;font-family:'Caveat',cursive;font-size:17px;padding:4px 0;outline:none;}
.note-inp::placeholder{color:rgba(255,255,255,0.17);}
.nb{font-size:13px;background:none;border:1px solid rgba(255,255,255,0.18);color:rgba(255,255,255,0.38);padding:4px 10px;cursor:pointer;letter-spacing:1px;transition:all 0.2s;font-family:'Caveat',cursive;}
.nb:hover{color:white;border-color:white;}
.nb-x{border-color:transparent!important;color:rgba(255,255,255,0.12)!important;}

/* ============ MODAL ============ */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,0.88);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.26s;padding:18px;}
.modal-bg.open{opacity:1;pointer-events:all;}
.modal{width:min(640px,96vw);max-height:82vh;overflow-y:auto;border:1px solid rgba(255,255,255,0.13);background:#0b0b0b;padding:26px 28px 32px;position:relative;transform:translateY(11px);transition:transform 0.26s ease;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.09) transparent;}
.modal-bg.open .modal{transform:translateY(0);}
.mx{position:absolute;top:12px;right:15px;font-size:20px;color:var(--dim);background:none;border:none;cursor:pointer;transition:color 0.2s;font-family:sans-serif;}
.mx:hover{color:white;}
.mh{font-family:'Dancing Script',cursive;font-size:23px;margin-bottom:4px;letter-spacing:2px;}
.mr{width:30px;height:1px;background:rgba(255,255,255,0.12);margin-bottom:15px;}

/* upload bar */
.upload-bar{display:flex;justify-content:flex-end;align-items:center;gap:10px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--faint);}
.upload-label{font-size:12px;color:var(--dim);letter-spacing:1px;}
.upl-btn{font-family:'Caveat',cursive;font-size:12px;color:rgba(255,255,255,0.38);background:none;border:1px solid rgba(255,255,255,0.15);padding:3px 10px;cursor:pointer;transition:all 0.2s;letter-spacing:1px;}
.upl-btn:hover{color:white;border-color:white;}

/* articles - 我的衣裳 */
.art-item{display:flex;justify-content:space-between;align-items:baseline;padding:10px 0;border-bottom:1px solid var(--faint);cursor:pointer;gap:8px;}
.art-item:hover .at{letter-spacing:2px;color:white;}
.at{font-size:17px;transition:letter-spacing 0.22s,color 0.2s;flex:1;}
.ad{font-size:11px;color:var(--dim);letter-spacing:1px;white-space:nowrap;}
.a-del{font-size:12px;color:rgba(255,255,255,0.18);background:none;border:none;cursor:pointer;padding:0 4px;transition:color 0.2s;flex-shrink:0;}
.a-del:hover{color:#e88;}
.art-body{display:none;padding:12px 0 4px;font-family:'Noto Serif SC',serif;font-size:13.5px;line-height:2.1;color:rgba(255,255,255,0.52);border-bottom:1px solid var(--faint);}
.art-body.open{display:block;}

/* drawer notes - 灵感碎布 */
.nc{border:1px solid var(--faint);padding:11px 12px 11px;margin-bottom:8px;font-size:14px;line-height:1.7;color:rgba(255,255,255,0.68);position:relative;padding-right:32px;}
.nts{font-size:10px;color:var(--dim);margin-top:4px;letter-spacing:1px;}
.n-del{position:absolute;top:10px;right:10px;font-size:13px;color:rgba(255,255,255,0.15);background:none;border:none;cursor:pointer;transition:color 0.2s;}
.n-del:hover{color:#e88;}

/* album */
.asp-spread{display:grid;grid-template-columns:1fr 3px 1fr;border:1px solid rgba(255,255,255,0.11);background:#070707;}
.asp-page{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:6px;padding:11px;}
.ps{aspect-ratio:1;border:1px dashed rgba(255,255,255,0.14);display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--dim);letter-spacing:1px;cursor:pointer;transition:border-color 0.2s;position:relative;overflow:hidden;}
.ps:hover{border-color:rgba(255,255,255,0.32);}
.ps img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.ps-cap{position:absolute;left:6px;right:6px;bottom:6px;padding:4px 6px;background:linear-gradient(180deg,transparent,rgba(0,0,0,0.82));color:rgba(255,255,255,0.86);font-size:10px;line-height:1.3;letter-spacing:0.4px;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none;}
.ps-del{position:absolute;top:3px;right:3px;font-size:11px;background:rgba(0,0,0,0.65);color:rgba(255,255,255,0.45);border:none;border-radius:50%;width:18px;height:18px;cursor:pointer;display:none;align-items:center;justify-content:center;transition:color 0.2s;}
.ps:hover .ps-del{display:flex;}
.ps-del:hover{color:#e88;}
.asp-spine{background:rgba(255,255,255,0.1);}
.an{display:flex;justify-content:space-between;align-items:center;margin-top:10px;}
.ab2{font-size:13px;color:var(--dim);background:none;border:none;cursor:pointer;letter-spacing:1px;transition:color 0.2s;font-family:'Caveat',cursive;}
.ab2:hover{color:white;}
.apg{font-size:11px;color:var(--dim);letter-spacing:2px;}
.album-photo-modal{width:min(760px,96vw);}
.album-photo-frame{border:1px solid rgba(255,255,255,0.11);background:#050505;padding:12px;margin-bottom:14px;}
.album-photo-image{display:block;width:100%;max-height:62vh;object-fit:contain;}
.album-caption-block{display:flex;flex-direction:column;gap:8px;}
.album-caption-label{font-size:12px;color:var(--dim);letter-spacing:1px;}
.album-caption-input{width:100%;min-height:110px;resize:vertical;background:#090909;border:1px solid rgba(255,255,255,0.12);color:rgba(255,255,255,0.82);padding:12px 14px;font-family:'Noto Serif SC',serif;font-size:13px;line-height:1.8;outline:none;}
.album-caption-input:focus{border-color:rgba(255,255,255,0.32);}

/* media */
.m-tabs{display:flex;border-bottom:1px solid var(--faint);margin-bottom:13px;}
.mtb{font-size:13px;padding:6px 15px 8px;cursor:pointer;color:var(--dim);background:none;border:none;letter-spacing:2px;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color 0.2s,border-color 0.2s;font-family:'Caveat',cursive;}
.mtb.on{color:white;border-bottom-color:rgba(255,255,255,0.45);}
.mpnl{display:none;}.mpnl.on{display:block;}
.fw{border:1px solid rgba(255,255,255,0.12);}
.fstrip{height:21px;display:flex;align-items:center;padding:0 6px;gap:4px;background:rgba(255,255,255,0.018);overflow:hidden;}
.fh{width:11px;height:7px;flex-shrink:0;border:1px solid rgba(255,255,255,0.2);border-radius:2px;}
.fscr{aspect-ratio:16/9;background:#030303;display:flex;align-items:center;justify-content:center;color:var(--dim);font-size:12px;letter-spacing:2px;position:relative;overflow:hidden;}
.fscl{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.055) 2px,rgba(0,0,0,0.055) 4px);pointer-events:none;}
.fctrl{display:flex;justify-content:center;gap:16px;padding:8px 10px;border-top:1px solid var(--faint);}
.fb{font-size:13px;color:var(--dim);background:none;border:none;cursor:pointer;letter-spacing:1px;transition:color 0.2s;font-family:'Caveat',cursive;}
.fb:hover{color:white;}
/* music */
.mbox{border:1px solid rgba(255,255,255,0.12);padding:18px;background:#070707;}
.mtop{text-align:center;margin-bottom:14px;}
.mname{font-family:'Dancing Script',cursive;font-size:20px;letter-spacing:2px;}
.mart{font-size:11px;color:var(--dim);letter-spacing:2px;margin-top:2px;}
.varea{display:flex;justify-content:center;margin-bottom:15px;}
.vinyl{width:94px;height:94px;border-radius:50%;border:1px solid rgba(255,255,255,0.2);position:relative;animation:spin 5s linear infinite;animation-play-state:paused;background:radial-gradient(circle,#1c1c1c 26%,#0a0a0a 26%,#0a0a0a 28%,rgba(255,255,255,0.05) 28%,rgba(255,255,255,0.05) 29%,#0a0a0a 29%,#0a0a0a 44%,rgba(255,255,255,0.035) 44%,rgba(255,255,255,0.035) 45%,#0a0a0a 45%,#0a0a0a 60%,rgba(255,255,255,0.025) 60%,rgba(255,255,255,0.025) 61%,#0a0a0a 61%);}
.vinyl.spin{animation-play-state:running;}
@keyframes spin{to{transform:rotate(360deg);}}
.vdot{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;}
.vdot::after{content:'';width:7px;height:7px;border-radius:50%;border:1px solid rgba(255,255,255,0.26);}
.pwrap{margin-bottom:10px;}
.pbar{width:100%;height:2px;background:rgba(255,255,255,0.07);cursor:pointer;position:relative;margin-bottom:4px;}
.pfill{height:100%;background:rgba(255,255,255,0.45);width:0%;transition:width 0.8s linear;pointer-events:none;}
.ptimes{display:flex;justify-content:space-between;font-size:10px;color:var(--dim);letter-spacing:1px;}
.mctrl{display:flex;justify-content:center;align-items:center;gap:20px;}
.mcb{font-size:14px;color:var(--dim);background:none;border:none;cursor:pointer;transition:color 0.2s;font-family:'Caveat',cursive;}
.mcb:hover{color:white;}
.mcm{font-size:18px;color:rgba(255,255,255,0.7);width:40px;height:40px;border:1.5px solid rgba(255,255,255,0.25)!important;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.mcm:hover{color:white;border-color:white!important;}
.tlist{margin-top:12px;border-top:1px solid var(--faint);}
.ti{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--faint);cursor:pointer;font-size:13px;color:var(--dim);transition:color 0.2s;}
.ti:hover,.ti.cur{color:rgba(255,255,255,0.78);}
.tn{width:14px;font-size:10px;}.tm{flex:1;padding:0 8px;}.td{font-size:10px;letter-spacing:1px;}
.t-del{font-size:11px;color:rgba(255,255,255,0.14);background:none;border:none;cursor:pointer;transition:color 0.2s;padding:0 3px;}
.t-del:hover{color:#e88;}

/* travel journal */
.travel-book{margin-bottom:18px;border:1px solid rgba(255,255,255,0.13);}
.travel-cover{display:flex;justify-content:space-between;align-items:center;padding:13px 15px;cursor:pointer;transition:background 0.2s;}
.travel-cover:hover{background:rgba(255,255,255,0.03);}
.tc-title{font-family:'Dancing Script',cursive;font-size:20px;letter-spacing:1px;}
.tc-date{font-size:11px;color:var(--dim);letter-spacing:1px;}
.tc-del{font-size:12px;color:rgba(255,255,255,0.15);background:none;border:none;cursor:pointer;transition:color 0.2s;padding:0 4px;}
.tc-del:hover{color:#e88;}
.travel-content{display:none;padding:14px 15px 16px;border-top:1px solid var(--faint);font-family:'Noto Serif SC',serif;font-size:13px;line-height:2;color:rgba(255,255,255,0.5);}
.travel-content.open{display:block;}
.travel-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:12px;}
.tp-slot{aspect-ratio:1;border:1px dashed rgba(255,255,255,0.13);display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--dim);cursor:pointer;position:relative;overflow:hidden;}
.tp-slot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.travel-add-btn{font-family:'Caveat',cursive;font-size:13px;color:rgba(255,255,255,0.28);background:none;border:1px dashed rgba(255,255,255,0.14);padding:7px 16px;cursor:pointer;width:100%;margin-top:10px;letter-spacing:2px;transition:all 0.2s;}
.travel-add-btn:hover{color:white;border-color:white;}

/* novel */
.ni{padding:12px 0;border-bottom:1px solid var(--faint);cursor:pointer;display:flex;justify-content:space-between;align-items:baseline;gap:8px;}
.ni-l{flex:1;}
.ntit{font-family:'Dancing Script',cursive;font-size:22px;transition:letter-spacing 0.28s;}
.ni:hover .ntit{letter-spacing:3px;}
.nex{font-family:'Noto Serif SC',serif;font-size:12px;color:rgba(255,255,255,0.3);margin-top:4px;line-height:1.8;}
.ni-full{display:none;padding:11px 0 5px;font-family:'Noto Serif SC',serif;font-size:13px;line-height:2.1;color:rgba(255,255,255,0.5);border-bottom:1px solid var(--faint);}
.ni-full.open{display:block;}

/*album delet*/
.ps-del {
  position: absolute;
  top: 4px;
  right: 4px;
  background: rgba(0,0,0,0.6);
  color: white;
  border: none;
  border-radius: 50%;
  width: 22px;
  height: 22px;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  opacity: 0;
  transition: opacity 0.2s;
}

.ps:hover .ps-del {
  opacity: 1;
}

/* article inline form */
#art-inline-form {
  border: 1px solid rgba(255,255,255,0.13);
  padding: 14px 16px 16px;
  margin-bottom: 14px;
  animation: fadeUp 0.22s ease forwards;
}
.art-form-inner { display: flex; flex-direction: column; gap: 10px; }
.art-title-inp,
.art-date-inp,
.art-content-inp {
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(255,255,255,0.15);
  color: rgba(255,255,255,0.82);
  font-family: 'Caveat', cursive;
  font-size: 16px;
  padding: 5px 0;
  outline: none;
  width: 100%;
  transition: border-color 0.2s;
}
.art-title-inp { font-size: 19px; }
.art-title-inp::placeholder,
.art-date-inp::placeholder { color: rgba(255,255,255,0.18); }
.art-content-inp {
  font-family: 'Noto Serif SC', serif;
  font-size: 13px;
  line-height: 1.9;
  resize: vertical;
  border: 1px solid rgba(255,255,255,0.1);
  padding: 10px 12px;
  margin-top: 4px;
  color: rgba(255,255,255,0.55);
}
.art-content-inp::placeholder { color: rgba(255,255,255,0.15); }
.art-title-inp:focus,
.art-date-inp:focus { border-bottom-color: rgba(255,255,255,0.45); }
.art-content-inp:focus { border-color: rgba(255,255,255,0.3); }
.art-form-btns { display: flex; gap: 10px; justify-content: flex-end; margin-top: 4px; }
.art-form-save,
.art-form-cancel {
  font-family: 'Caveat', cursive;
  font-size: 13px;
  background: none;
  border: 1px solid rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.38);
  padding: 4px 14px;
  cursor: pointer;
  letter-spacing: 1px;
  transition: all 0.2s;
}
.art-form-save:hover { color: white; border-color: white; }
.art-form-cancel:hover { color: #e88; border-color: #e88; }
